

Transmitter Programming Interface (TPI)
Programmer's Reference

Document # SiI-PR-1032-0.77

April 2010

### **Copyright Notice**

Copyright © 2010, 2009 Silicon Image, Inc. All rights reserved. These materials contain proprietary and confidential information (including trade secrets, copyright and other interests) of Silicon Image, Inc. You may not use these materials except only for your bona fide non-commercial evaluation of your potential purchase of products and/or services from Silicon Image or its affiliates, and/or only in connection with your purchase of products and/or services from Silicon Image or its affiliates, and only in accordance with the terms and conditions herein. You have no right to copy, modify, transfer, sublicense, publicly display, create derivative works of or distribute these materials, or otherwise make these materials available, in whole or in part, to any third party.

### **Trademark Acknowledgment**

Silicon Image<sup>TM</sup>, VastLane<sup>TM</sup>, SteelVine<sup>TM</sup>, PinnaClear<sup>TM</sup>, Simplay<sup>TM</sup>, Simplay HD<sup>TM</sup>, Satalink<sup>TM</sup>, and TMDS<sup>TM</sup> are trademarks or registered trademarks of Silicon Image, Inc. in the United States and other countries. HDMI<sup>TM</sup>, the HDMI logo and High-Definition Multimedia Interface<sup>TM</sup> are trademarks or registered trademarks of, and are used under license from, HDMI Licensing, LLC.

#### **Further Information**

To request other materials, documentation, and information, contact your local Silicon Image, Inc. sales office or visit the Silicon Image, Inc. web site at <a href="https://www.siliconimage.com">www.siliconimage.com</a>.

### **Revision History**

| Revision | Date     | Comment                                                            |
|----------|----------|--------------------------------------------------------------------|
| 0.77     | 04-09-10 | Update wakeup support in D3 Cold and Hot for SiI 9022A/ SiI 9024A. |
|          |          | Clarify RESET value.                                               |
|          | 0,00     | Removed comment about 3D modes and DE generator.                   |
| 0.76     | 03-08-10 | Revised Programmer's Reference release.                            |
|          |          | Updates for SiI9136/9334:                                          |
|          |          | - Added workaround for HBR audio (added V bit programming)         |
|          |          | - Revised Ri Read section                                          |
|          |          | - Fixed Video Black Mode Register access                           |
|          |          | - Added video output programming section                           |
|          |          | - Fixes for KSV Forward                                            |
|          |          | - Fixes for range control                                          |
|          |          |                                                                    |

| Silicon Image, Inc. |           |                                                                                                                          |
|---------------------|-----------|--------------------------------------------------------------------------------------------------------------------------|
| 0 /                 |           |                                                                                                                          |
| 0.75                | 02-04-10  | Revised Programmer's Reference release.                                                                                  |
|                     |           | Updates for SiI9136/9334:                                                                                                |
|                     |           | - Update SiI9136/9334 Revision ID                                                                                        |
|                     |           | - Add Hot Plug Delay De-bounce                                                                                           |
|                     |           | - Update explicit Sync DE Generator values for H_RES, DE_CNT, DE_LIN                                                     |
|                     |           | - Indicate Bit swap and YC Channel swap features function without enable                                                 |
|                     |           | - Add Ri Read, Bcaps and Bstatus                                                                                         |
|                     |           | - Add VSYNC and HSYNC polarity to Embedded Sync Extraction Registers                                                     |
|                     |           | - Indicate re-write of TPI 0x60 after setting AVI InfoFrame not necessary                                                |
|                     |           | - Remove 2x clocking setting from 16bit deep color setting                                                               |
|                     |           | - Video Black Mode Levels provided for Black Mode of Video Input Mode                                                    |
|                     |           | - When TPI 0x1A transitions from DVI to HDMI, then TPI 0x08[1:0] is no                                                   |
|                     |           | longer cleared                                                                                                           |
|                     |           | - Remove manual configuration for 192kHz S/PDIF with 480i video                                                          |
|                     |           | - Muting works in DVI mode                                                                                               |
|                     |           | - Deep Color modes require GCP to send deep color information, this must be                                              |
|                     |           | enabled by software                                                                                                      |
|                     |           | - Add TPI Soft Reset Register                                                                                            |
|                     |           | - Removed incorrect restrictions on H_Res for 3D modes                                                                   |
|                     |           | - Updated HEAC information with latest recommendations                                                                   |
| 0.74                | 09-21-09  | Revised Programmer's Reference release.                                                                                  |
|                     |           | Changes:                                                                                                                 |
|                     |           | - Removed incorrect restriction on H_RES for 3D modes                                                                    |
|                     |           | - Updated HEAC information with latest recommendations                                                                   |
|                     |           | - Removed SiI9230/9234 Tx references (moved to separate document)                                                        |
|                     |           | - Added notes of interest to describe details of HDCP operation.                                                         |
| 0.73                | 08-18-09  | Revised Programmer's Reference release.                                                                                  |
|                     |           | Changes:                                                                                                                 |
|                     | . ( ) . \ | - Corrected description of TPI 0x1F (I <sup>2</sup> S register)                                                          |
|                     |           | - Clarified description of authentication success/fail status                                                            |
|                     |           | <ul> <li>Added supported 3D mode descriptions</li> <li>Clarified Access requirements in register descriptions</li> </ul> |
|                     |           | - Added clarification notes for SiI9136/9334 Tx operation                                                                |
|                     | 7.69      | - Modified DE_ADJ# setting recommendation                                                                                |
| 0.72                | 06-15-09  | Revised Programmer's Reference release.                                                                                  |
| v., <b>2</b>        | 00 12 07  | Changes:                                                                                                                 |
|                     |           | - Added ARC and HEAC sections.                                                                                           |
|                     |           | - Added significant information and corrections to most sections.                                                        |
| 0.71                | 02-27-09  | Revised Programmer's Reference release.                                                                                  |
|                     |           | Changes:                                                                                                                 |
|                     | 12.       | - Removed "Advance" from title, because this document is mature for most                                                 |
|                     |           | products represented.                                                                                                    |
|                     |           | - Added additional information for new and upcoming products                                                             |
| 0.70                | 11-18-08  | Initial Advance Programmer's Reference release.                                                                          |
|                     |           |                                                                                                                          |

© 2009, 2010 Silicon Image. Inc.

# **Table of Contents**

| Overview                                         |           |
|--------------------------------------------------|-----------|
| Register Group Summary                           |           |
| Transmitter Programming Interface (TPI)          | 2         |
| Internal (Indexed) Registers                     | 2         |
| Device-Specific Information                      |           |
| SiI9022 and SiI9024 Tx                           | 3         |
| SiI9022A and SiI9024A Tx                         | 3         |
| SiI9136 Tx and SiI9334 Tx                        | 4         |
| I <sup>2</sup> C Requirements                    | 5         |
| Summary of Host Software Tasks                   | 6         |
| Detailed Sequences                               | 7         |
| Initialization                                   | 7         |
| Servicing a Hot Plug Event                       | 8         |
| Changing Video Modes                             |           |
| HDCP Authentication and Encryption               | 9         |
| HDCP Revocation Check                            | 9         |
| General Programming Registers                    | 10        |
| Important Notes                                  | 10        |
| Identification                                   | <b>11</b> |
| Important Notes                                  | 12        |
| Video Mode                                       | 12        |
| Output color space control (SiI9334 and SiI9136) | 17        |
| Innuit Catum Omanations                          | 10        |
| DE Generator Register Set                        | 21        |
| Intoframe Data                                   | 24        |
| Using x y Color                                  | 26        |
| Using x.v.Color Extended Colorimetry Standards   | 26        |
| System Control                                   | 27        |
| Audio Configuration                              | 29        |
| Configuring Audio using S/PDIF                   | 29        |
| Configuring Audio using 0.7 251                  | 31        |
| Configuring Audio for DSD Format                 | 35        |
| Configuring Audio for HBR Format                 | 35<br>35  |
| Interrupt Service                                | 36<br>36  |
| Interrupt Enable Register                        | 36        |
| Interrupt Status Register                        | 36        |
| Interrupt Operation                              | 38        |
| TPI System Reset And Control                     | 39        |
| Power State Control and Hot Plug Management      | 40        |
| Transmitter Power State Register                 |           |
| Hot vs Cold Wakeup Modes                         | 42        |
| Hot Plug Management                              | 42        |
| Hot Plug Service Loop                            | 42        |
| Operating Sequences                              |           |
| HDCP Implementation                              |           |
| Control for HDCP                                 |           |
| HDCP Operation                                   |           |
| HDCP Data Structure                              |           |
| Auxiliary HDCP Registers                         |           |
| Appendix A – SiI9020 Tx Compatible Mode          |           |
| SiI9020-9022-9022A Transmitter Mode Differences  |           |
| PLL Settings.                                    |           |
| DDC Bus Request/Grant                            |           |
| Video Black Mode                                 |           |
|                                                  |           |

### Silicon Image, Inc.

| Power-Down Register                             | 56 |
|-------------------------------------------------|----|
| Transmitter Mode after Reset                    | 56 |
| Appendix B – Mobile HD Link                     | 57 |
| Detailed Programming Requirements               | 58 |
| I <sup>2</sup> C Requirements                   | 58 |
| Identification                                  | 59 |
| Initialization                                  | 59 |
| Reset                                           | 59 |
| Connection and Discovery                        | 60 |
| CTRL Bus Configuration                          | 60 |
| Initializing the CTRL Bus Registers             | 60 |
| Transmitter Power State                         | 61 |
| Maximum Speed Limitations                       | 62 |
| Interrupt Service                               |    |
| TPI 0x3D[0]: Hot Plug/Connection Event          | 62 |
| TPI 0x3D[1]: RxSense Event or CTRL Bus Error    | 63 |
| TPI 0x3D[2]: CTRL Bus Transaction Event         | 63 |
| Non Maskable Interrupt                          | 63 |
| Non Maskable Interrupt                          | 64 |
| Appendix D – SiI9136 Tx and SiI9334 Tx Features | 67 |
| Special x.v.Color Features                      | 67 |
| Color Space Conversion                          | 67 |
| 3D Support                                      | 68 |
| 3D Formats Supported                            | 68 |
| HDMI Vendor Specific InfoFrame                  | 68 |
| Sink EDID Vendor Specific Data Block            | 69 |
| Pixel Clock                                     | 69 |
| Limitations                                     | 69 |
| General Purpose I/O                             | 70 |

# **List of Figures**

| Figure 1. Transmitter Data Flow Paths                                             | 1           |
|-----------------------------------------------------------------------------------|-------------|
| Figure 2. Transmitter TPI Register Interface to Host                              | 10          |
| Figure 3. Input Bus Diagram for Different Formats                                 | 15          |
| Figure 4. Transmitter Video Data with Sync Decoding                               |             |
| Figure 5. DE Generator Measurements.                                              |             |
| Figure 6. INT Pulse on Event other than HTPLG                                     |             |
| Figure 7. Hot Plug Control Output Timing                                          |             |
| Figure 8. Hot Plug Control Output Timing                                          |             |
| 1.gute of 1100 1 tag control curput 1.mmg                                         |             |
|                                                                                   |             |
| Figure B - 1. Typical Mobile HD Link Solution                                     | 57          |
|                                                                                   |             |
| , (/)                                                                             |             |
| Table 1. Register Group Summary                                                   | 1           |
| Toble 1 Decistor Crown Summers                                                    |             |
| Table 2. Comparison of Logogy Pogistors to TDI Pogistors                          | 4           |
| Table 2. Comparison of Legacy Registers to TFI Registers                          | 1:          |
| Table 5. 1P1 Identification Registers (RO)                                        | 11<br>11    |
| Table 4. Device ID Information                                                    | 1           |
| Table 5. TPI Video Mode Data (R/W)                                                | 12          |
| Table 6. TPI Input Bus and Pixel Repetition Data (R/W)                            |             |
| Table 7. TPI Frequency Multiplication Ratio (R/W)                                 | <i>I</i> 13 |
| Table 8. 480p Mode Format Matching Example                                        | 14          |
| Table 9. TPI AVI Input and Output Format Data (R/W)                               | 16          |
| Table 10. TPI Video Mute Registers (R/W)                                          | 17          |
| Table 8. 480p Mode Format Matching Example                                        | 19          |
| Table 12. TPI YC Input Mode Select (R/W)                                          | 20          |
| Table 13. Explicit Sync DE Generator Registers (TPI 0x60 /  = 0)                  | 22          |
| Table 14. Embedded Sync Extraction Registers (TPI 0x60[7] = 1)                    | 23          |
| Table 15. TPI AVI InfoFrame Data (R/W)                                            | 24          |
| Table 16. TPI Miscellanous InfoFrame Data (R/W)                                   | 25          |
| Table 17. TPI System Control (R/W)                                                | 27          |
| Table 18. TPI Audio Configuration Write Data (RW)                                 | 30          |
| Table 19. Configuration of I <sup>2</sup> S Interface (RW)                        | 32          |
| Table 20. Mapping of I <sup>2</sup> S Interface (RW)                              | 32          |
| Table 21. Audio Packet Header Layout Indicator (R/W)                              | 33          |
| Table 21. Audio Packet Header Layout Indicator (R/W)                              | 33          |
| Table 23. Word Length Selection (R/W)                                             | 34          |
| Table 24. TPI Interrupt Enable (R/W)                                              | 36          |
| Table 25. TPI Interrupt Status (R/W)                                              |             |
| Table 26. TPI Soft Reset (R/W)                                                    | 30          |
| Table 27. TPI Device Power State Control Data (R/W)                               |             |
| Table 28. Mapping of HDCP Data to TPI Register Bits                               |             |
| Table 29. TPI Security Registers                                                  |             |
| Table 30. TPI HDCP Revision Data (RO)                                             |             |
|                                                                                   |             |
| Table 31. TPI KSV and V* Value Data (R/W)                                         |             |
| Table 32. TPI V* Value Readback Data (RO)                                         |             |
| Table 33. TPI Aksv Readback Data (RO)                                             |             |
| Table 34. TPI KSV Forward (RO)                                                    |             |
| Table 35. TPI BCAPS (RO)                                                          |             |
| Table 36. TPI BSTATUS (RO)                                                        |             |
| Table A - 1. PLL Programming Registers – SiI9020 Mode Only (R/W)                  |             |
| Table A - 2. SiI9020 Tansmitter Mode Difference – PLL Setup (R/W)                 |             |
| Table A - 3. SiI9020 Transmitter Mode Difference – Request/Grant/Black Mode (R/W) | 56          |

### Silicon Image, Inc.

| Table A - 4. Power-Down Register for SiI9020 Transmitter Register-Compatible Mode (R/W) | 56 |
|-----------------------------------------------------------------------------------------|----|
| Table B - 1. Mobile HD Link Products Described in this Appendix                         | 57 |
| Table B - 2. TPI Identification Registers (RO)                                          | 59 |
| Table B - 3. Device ID Information                                                      | 59 |
| Table B - 4. CTRL Bus – Command Registers                                               | 60 |
| Table B - 5. CTRL Bus – Command Definitions                                             | 61 |
| Table B - 6. TPI Device Power State Control Data (R/W)                                  | 61 |
| Table B - 7. Connection Event Triggers                                                  | 62 |
| Table B - 8. CTRL Bus Error Event Triggers                                              | 63 |
| Table B - 9. TPI Interrupt Status (R/W)                                                 |    |
| Table C - 1. HEAC Module Configuration 1 (R/W)                                          | 64 |
| Table C - 2. HEAC Module Configuration 2 (R/W)                                          | 65 |
| Table D - 1. x.v.Color Control (R/W)                                                    | 67 |
| Table D - 2. x.v.Color Coefficient Override Table Access (R/W)                          | 67 |
| Table D - 3. SiI9136/9334 Tx InfoFrame Options (R/W)                                    | 68 |
| Table D - 4. GPIO Configuration                                                         | 70 |
|                                                                                         |    |

Silconited ectionial silconited and the silconited



### Overview

Silicon Image HDMI transmitter solutions merge independent video and audio streams for transmission over HDMI. To do this, the transmitter employs a unique mechanism that allows host graphics and audio software to interact with the HDMI transmitter.

All new devices implement a simplified interface and special logic that automates most HDMI functions. This Transmitter Programming Interface (TPI) maps a concise set of registers into I<sup>2</sup>C address space that the host can readily access.

TPI offers a significantly simplified operating scheme, using built-in hardware to handle tasks such as the following.

- Secure operation is fully automatic on devices equipped with HDCP. With only a single-bit write, the device establishes and maintains link security, interrupting the host only if the secure link is lost.
- DDC arbitration is handled cleanly, allowing the host to simply request the bus and then fetch EDID information directly – no need to program transfers into or out of a FIFO. Arbitration is handled even when link security is enabled.
- Complex audio setup is nearly eliminated. Hardware calculates N/CTS values and automatically sends out the appropriate packet information with no setup needed.
- All frequency-dependent internal settings, such as for PLLs, are derived automatically in hardware from the video mode information that has been programmed.

#### In addition:

- Devices still implement the standard Silicon Image register set used by legacy transmitters, for backwards compatibility with special functions in existing code.
- All devices implement an automated CEC controller, using the Silicon Image standard CEC Programming Interface (CPI).
- Many versions additionally support HDCP, implemented as part of the automated solution and requiring no host intervention for normal operation.

This document describes the TPI programming solution for the following devices.

|   | HDCP-<br>enabled<br>Version | Non HDCP-<br>enabled<br>Version | enabled this existing |                    |
|---|-----------------------------|---------------------------------|-----------------------|--------------------|
|   | SiI9024 Tx                  | SiI9022 Tx                      | SiI9020 Tx            | HDMI Mobile        |
|   | SiI9024A Tx                 | SiI9022A Tx                     | SiI9022/24 Tx         | HDMI Mobile        |
|   | SiI9136 Tx<br>SiI9334 Tx    | - X                             | SiI9034 Tx            | STB, PVR,<br>AVR   |
| 1 | SiI9222 Tx                  | SiI9226 Tx                      |                       | Mobile HD<br>Link* |
| - | SiI9232 Tx                  | SiI9236 Tx                      | <u> </u>              | Mobile HD<br>Link* |

\* Mobile HD Link solutions have additional programming requirements covered in Appendix B.

Figure 1 illustrates the major functional blocks for a typical TPI-based transmitter solution.



Figure 1. Transmitter Data Flow Paths

# **Register Group Summary**

### **Transmitter Programming Interface (TPI)**

TPI provides a programming interface that operates at a higher hardware level than traditional register file interfaces. The TPI register groups below handle all normal chip operations in a concise format.

**Table 1. Register Group Summary** 

| Group<br>Function                                                      | Register<br>Addresses        | Page  | Register<br>Name                        | What Firmware Does<br>with these Registers                                                          |
|------------------------------------------------------------------------|------------------------------|-------|-----------------------------------------|-----------------------------------------------------------------------------------------------------|
| Identification                                                         | 0x1B-1D                      | 11    | Identification                          | Identifies the chip and version of TPI implemented.                                                 |
| Input Configuration – one-<br>time configuration of the                | 0x08                         | 13    | Input Bus and<br>Pixel Repetition       | Selects input bus characteristics like pixel size, clock edge                                       |
| input bus for its application environment.                             | 0x0B                         | 19    | YC Input Mode<br>Select                 | Selects YC Mux modes, signal timing features, and chooses sync method registers to access           |
|                                                                        | 0x60-61                      | 18    | Sync<br>Configuration and<br>Monitoring |                                                                                                     |
|                                                                        | 0x62-6D<br>with<br>0x60[7]=0 | 21    | Explicit Sync DE<br>Generation          | Defines parameters for explicit sync method                                                         |
|                                                                        | 0x62-6D<br>with<br>0x60[7]=1 | 23    | Embedded Sync<br>Extraction             | Defines parameters for embedded sync method                                                         |
| Audio Configuration                                                    | 0x1F-0x28                    | 29    | Audio<br>Configuration                  | Configures audio input channels and rates                                                           |
| Video Mode Select –                                                    | 0x00-0x07                    | 12    | Video Mode                              | Defines the incoming resolution                                                                     |
| resolution, color space,<br>InfoFrame headers                          | 0x09-0A                      | 15    | Input and Output<br>Format              | Defines color space, color depth                                                                    |
| 6                                                                      | 0x0C-0x19<br>0xBF-0xDE       | 24 25 | AVI InfoFrame Other InfoFrame           | Programs header information as defined by HDMI specification                                        |
|                                                                        | 0x60                         | 19    | YC Mux Mode                             |                                                                                                     |
| System Control – single-byte<br>control for most-used<br>functions     | 0x1A                         | 26    | System Control                          | Requests DDC bus access, selects between DVI/HDMI, controls TMDS output and AV Mute                 |
| Interrupt – single-byte status<br>for monitoring significant<br>events | 0x3C-3D                      | 36    | Interrupt                               | Polls for and clears events, selects the interrupt events that should cause hardware INT activation |
| Power Control                                                          | 1E                           | 40    | Power Control                           | Selects full-power operational mode or low-power standby mode                                       |
| HDCP – automatic security                                              | 0x29-0x3A                    | 45    | HDCP                                    | Sets up and monitors HDCP link security                                                             |

### **Internal (Indexed) Registers**

Underlying the TPI register set is a broader and more complex internal register set that is normally hidden from direct access. This register set includes the "legacy" registers that were available in older programming methodologies, but also some additional registers that are used primarily during chip development and testing.

From time to time, situations arise that require customer software to manually access these internal registers. Therefore, a mechanism is provided for accessing single bytes. Where defined, Internal Registers are accessed as noted below.

| 1. Set Page | 2. Select Indexed Offset within Page | 3. Obtain Read/Write Register Access |  |
|-------------|--------------------------------------|--------------------------------------|--|
| 0xBC        | 0xBD                                 | 0xBE                                 |  |

### **Device-Specific Information**

Several documents are required for a full understanding of the system level operation of the chip. Information in the Data Sheet and starter kit User's Guide is specific to the device in question; references are provided in the appropriate section below. CEC information is common to all devices and is provided in the following document.

• SiI-PR-0041: CEC Programming Interface (CPI) Programmer's Reference

#### **SiI9022 and SiI9024 Tx**

The SiI9022 and SiI9024 transmitters are improved replacements for the SiI9020 Tx. The following additional documents are required for a full understanding of the system level operation of these chips.

- SiI-DS-1009: SiI9022/9024 HDMI Transmitter Data Sheet
- SiI-UG-1010: CP9022HDMI/9024HDMI Starter Kit User's Guide

#### Differences between SiI9022 and SiI9020 Transmitters

The default SiI9022 transmitter register set has been maintained identically from the SiI9020 transmitter, but with the following improvement.

- The SiI9020 transmitter implemented a hardware state machine to drive the DDC I<sup>2</sup>C bus. The host set up a transfer by programming a series of bytes, and then waited for the chip to complete the transfer and generate an interrupt.
- The SiI9022 transmitter implements an I<sup>2</sup>C pass-through mechanism, which is driven directly by the host as if the DDC device were on the local I<sup>2</sup>C bus. No transfer setup or interrupt service is required.

### Differences between SiI9024 and SiI9022 Transmitters

From a programming point of view, the SiI9024 transmitter has all the same features as the SiI9022 transmitter. Additionally, the SiI9024 transmitter contains an HDCP encryption engine and pre-programmed HDCP keys.

An extra register group is implemented in the SiI9024 transmitter to operate the HDCP function in a completely automatic way. Note that SiI9020 Compatible Mode operation (refer to Appendix A) cannot be chosen for the SiI9024 transmitter if HDCP is required, since the SiI9020 transmitter did not support HDCP.

### SiI9022A and SiI9024A Tx

The SiI9022A Tx and SiI9024A Tx are pin- and feature-compatible replacements for the SiI9022 Tx and SiI9024 Tx, respectively. Refer to SiI-DS-1053 – *SiI9022A/9024A HDMI Transmitter Data Sheet* – for additional information.

### Differences between SiI9022/SiI9024 and SiI9022A/SiI9024A Transmitters

Several new features have been added to the "A" version TPI register set, improving the ease of use.

- x.v.Color is supported by sending gamut descriptor packets (described in Other InfoFrame Data section).
- Top level TPI support is provided for TClkSel (TPI 0x08) and Audio Packet Layout Control (TPI 0x26).
- I<sup>2</sup>S Audio Input Word Length selection is now written automatically (TPI 0x25).
- CEC no longer requires calibration (refer to the CEC Programming Interface (CPI) Programmer's Reference (SiI-PR-0041).

Firmware that runs on the SiI9022 or SiI9024 transmitter will run unchanged on the "A" version of these parts. However, certain changes should be considered for most efficient operation.

- The D3 state now has an additional requirement to program the "Cold" mode to take advantage of the new lower-power TMDS core.
- Wakeup from Receiver Sense (RSEN) is not available in D3 Cold mode but, is available in D3 Hot mode..
- The devices come up in operational state after a hardware reset, with the TMDS output enabled. To enter an intermediate power mode similar to the reset state of a non "A" device, it is necessary to enter TPI mode (writing 00 to 0xC7).

Detection of HDCP capability on the "A" devices works slightly differently than on previous devices.

- On non "A" devices, software could read the HDCP revision ID register TPI 0x30 to distinguish SiI9024 Tx (HDCP-equipped) from SiI9022 Tx (not HDCP-equipped). A zero value indicated no HDCP support. This method is no longer supported on "A" devices.
- New method: To distinguish SiI9024A Tx (HDCP-equipped) from SiI9022 Tx or SiI9022A Tx (not HDCP-equipped), software must read the Aksv value from registers starting at TPI 0x36, and check for a valid value (20 1s and 20 0s). This method is a more secure means of verifying host HDCP capability.

### SiI9136 Tx and SiI9334 Tx

### Differences between SiI9034/9134 Tx and SiI9136/9334 Transmitters

The SiI9034 Tx and SiI9134 Tx used an older register scheme that required significant software intervention and overhead to manage all aspects of operation. This "legacy" register set is replaced on the SiI9136/9334 Tx by TPI. The TPI logic scheme automates many tasks that previously required software support. As a result, the register set is greatly reduced, simplifying support code and reducing software overhead.

The need for specific legacy register support has been superseded by the TPI register set as shown in Table 2.

SiI9034/9134 Tx Register Group SiI9136/9334 Tx TPI Notes Correspondent I<sup>2</sup>C Device Group Name Reg Address 0x00-04 0x1B-1D 0x72 ID **ID Registers** System Control 0x08-0D 0x08 (edge, bsel) Clock stability monitoring is fully automated under and Status 0x1E (power ctrl) TPI, as are plug/unplug handling and power cycling. 0x3D (hpd, rsen) All parts of the HDCP authentication protocol are 0x0F-2B **HDCP** 0x29-46 fully automated under TPI. Register group is reduced from 35 bytes to 18. DE Generator and Embedded Sync register groups 0x32-3D, 0x60-0x6D Video 0x3E-47 are overlaid in TPI. 0x48-0x4E 0x09-0B 0x70-79 0x3C,3D Interrupt handling is consolidated, and most critical Interrupt events are handled automatically under TPI. Reading one byte returns all event information. Register group is reduced from 16 bytes to 2. TMDS PLL Filter PLL control settings are loaded automatically 0x0C0x00-01 0x80-85 under TPI, according to the frequency programmed. Register group is reduced to 2 bytes. Reset control is fully automated under TPI. No Reset 0x05 manual reset sequencing is required on frequency changes DDC, ROM 0xEC-F5. 0x1A Direct DDC bus access is granted, with no need for programmed transfers, under TPI. A single register 0xF9, 0xFA write gains access to the bus. Register group is reduced to 1 byte. Audio handling, including loading of N/CTS values, 0x7A Audio 0x00-3D 0x1F-28 is fully automated under TPI. Audio-related resets are no longer required. Register group is reduced to 10 bytes. 0x3E-FE 0x0C-19 Most packet groups are overlaid in TPI. Register Packet 0xBF-DE group is reduced from 192 bytes to 46.

Table 2. Comparison of Legacy Registers to TPI Registers

Additional differences are as follows.

• The SiI9334 Tx supports certain HDMI 1.4 features; these are described in Appendix D.

#### Silicon Image, Inc.

• Some legacy registers from the SiI9034/9134 Tx are available through an indirect (indexed) access mechanism on the SiI9136/9334 Tx. When the register page is written to TPI 0xBC, and the register index to TPI 0xBD, the legacy register becomes read/write accessible at TPI 0xBE. Software engineers who have needs not met by TPI can therefore revert to the legacy registers for special cases. Note that HDCP operation is not supported through legacy registers.

Refer to SiI-DS-1064 - SiI9334 HDMI Transmitter Data Sheet - for additional information.

#### Differences between SiI9024A Tx and SiI9136/9334 Transmitters

Firmware that runs on the SiI9024A Tx will run unchanged on the SiI9136/9334 Tx. However, some additional features listed below have been added to the SiI9136/9334 Tx.

- Supports 48 bit Deep Color at up to 1080p, 30 frames per second, as controlled by new register bits at TPI 0x09.
- Supports certain HDMI 1.4 features, described in Appendix D.
- Supports HBR Audio and DSD Audio, enabled through TPI 0x26.

Refer to SiI-DS-1064 - SiI9334 HDMI Transmitter Data Sheet - for additional information.

# I<sup>2</sup>C Requirements

The host must have hardware reset control over the transmitter, typically through a GPIO pin. The transmitter notifies the host of service needs through an interrupt line. All other communication occurs by way of the local  $I^2C$  interface.

I<sup>2</sup>C Access Speeds. The internal hardware I<sup>2</sup>C interface of the transmitter runs at speeds up to 400kHz. This throughput can also be achieved on the DDC interface, if the connected device supports it, when using the pass-through I<sup>2</sup>C feature of the TPI register set.

The host software is responsible for ensuring its DDC access speed does not exceed the limitations of any device present on the bus – all devices must be determined capable of supporting 400kHz operation before the host attempts to do any accesses at that speed. Speeds in excess of 100kHz may not be allowed by the interface specification in use.

→ Important Note: There is lower speed limit of 40kHz on DDC pass-through operation, except for the SiI9136 Tx and SiI9334 Tx which have a lower limit of 1kHz.

 $I^2C$  Access Addresses. The  $I^2C$  address used to access the TPI registers is 0x72. The transmitter can optionally respond at address 0x76 depending on the CI2CA hardware strap setting described in the transmitter Data Sheet. Certain legacy registers, not supported on all devices, respond at 0x7A (or 0x7E depending on CI2CA pin strapping).

The I<sup>2</sup>C address used to access the CPI registers is noted in the CEC Programming Interface (CPI) Programmer's Reference (SiI-PR-0041). The I<sup>2</sup>C address used to access the CTRL bus registers is noted in the "CTRL Bus Configuration" section.

In a TPI transmitter environment, the host masters one  $I^2C$  interface, and the transmitter masters another, as illustrated for a typical transmitter in Figure 1. For transmitters without HDCP capability, the  $I^2C$  paths are the same, but the DDC bus is not used for HDCP in this case.

- Host TPI/CPI/DDC I<sup>2</sup>C Interface. The transmitter implements this slave interface, mastered by the host. The host serially transmits and receives data over this bus, which implements a register interface structure where the host writes video mode and HDCP control data and reads back connection status information.
- **DDC I<sup>2</sup>C Interface.** When using the native TPI operating interface, the transmitter implements this interface as a pass-through connection from the host to the DDC bus of the HDMI TV. The transmitter has the ability to block the graphics host from accessing this bus when using it for HDCP, and also monitors the bus for activity to prevent breaking an active connection.

## **Summary of Host Software Tasks**

Managing TPI operations is straightforward, starting from when the host resets the subsystem after power-up.

**Initialization.** After reset, the subsystem comes up in a pre-determined state:

- Standby (D2) state for SiI9022 Tx, SiI9022A Tx, SiI9024 Tx, SiI9024A Tx
- Active (D0) state for SiI9136/9334 Tx.

Host software initializes it by:

- Configuring the registers according to known video/audio input format information
- Enabling any interrupt events to be signaled on the INT pin.

From this point, there are various service conditions that will be called for.

**Hot Plug Service.** Until a device is attached, the host just monitors the connection status either through interrupts or by polling. The host software waits for an attached Sink hot plug event, and then:

- Reads the downstream Sink EDID information
- Powers up the transmitter (D0 state)
- Sends active video corresponding to the Sink capabilities, and selects DVI or HDMI mode, depending on the EDID information found.

**Operational State.** The subsystem manages most routine HDMI activities in Operational state. The host software usually only needs to:

- Change video modes
- Enable HDCP operation and check the ksv list against known bad keys in the SRM
- Monitor ongoing HDCP operation, through interrupt service or by polling.

Unplug Service. Once the subsystem detects a hot unplug event, it:

- Notifies the host through INT (if the interrupt is enabled)
- Disables HDCP and restores certain other logic states
- On the next <u>plug-in</u> event, drives the INT pin active (if the interrupt was previously enabled).

Within the host software, Unplug Service events are typically handled by the Hot Plug Service routine.

**Reserved Bits.** Bits marked *Rsvd* or *Reserved* should be written as 0 when other bits in the register are accessed, unless otherwise noted.

### **Detailed Sequences**

In the following descriptions:

- 'host' refers to activities of the software for the graphics host processor.
- 'TPI' refers to use of the I<sup>2</sup>C interface to access the TPI registers implemented in the transmitter itself.
- 'Tx' refers to the respective transmitter chip variant. 'Rx' refers to the HDCP registers on the remote HDMI receiver.

### **Initialization**

The following steps are required to prepare for operation.

| Step | Function                | Registers   | See  | Details                                                                            |
|------|-------------------------|-------------|------|------------------------------------------------------------------------------------|
|      |                         | Involved    | page |                                                                                    |
| 1    | Reset and Initialize    | 0xC7        |      | host → TPI: Hardware Reset to Tx subsystem                                         |
|      |                         |             |      | The host must reset the chip, then write <b>0x00</b> to <b>0x72:0xC7</b> to enable |
|      |                         |             |      | TPI mode.                                                                          |
| 2    | Detect Revision         | 0x1B-0x1D   | 11   | host ← TPI: Detect Tx type and TPI revision.                                       |
|      |                         |             |      | When TPI 0x1B can be read correctly, the TPI subsystem is ready.                   |
| 3    | Power up transmitter    | 0x1E        | 40   | host → TPI: Enable active mode.                                                    |
|      |                         |             |      | Write TPI $0x1E[1:0] = 00$                                                         |
| 4    | Configure Input Bus and | 0x08        | 13   | host → TPI: Select input bus characteristics like pixel size, clock edge           |
|      | Pixel Repetition        |             |      |                                                                                    |
| 5    | Select YC               | 0x0B        | 19   | host → TPI: Select YC input mode and signal timing features                        |
|      | Input Mode              |             |      |                                                                                    |
| 6    | Configure               | 0x60-61     | 18   | host → TPI: Choose the sync method register group to access, enable YC             |
|      | Sync Methods            |             |      | Mux mode                                                                           |
| 7    | Configure Explicit Sync | 0x62-6D     | 21   | host → TPI: Define parameters for explicit sync method                             |
|      | DE Generation           | w/0x60[7]=0 | X    |                                                                                    |
| 8    | Configure Embedded      | 0x62-6D     | 23   | host → TPI: Define parameters for embedded sync method                             |
|      | Sync Extraction         | w/0x60[7]=1 |      | Note that the TPI 0x63 values must be rewritten after 0x19 is written.             |
| 9    | Set up                  | 0x3C        | 36   | host → TPI: Enable hardware interrupts to be serviced (TPI 0x3C).                  |
|      | Interrupt Service       |             |      |                                                                                    |

 $\rightarrow$  Important Note: For TPI operation, always write device address 0x72, register offset 0xC7 = 0x00 as the first step after hardware reset. (This step is not required on the SiI9222/9226 device.)

Step 1 above is <u>mandatory</u> to allow operation of the TPI register set on HDMI transmitters. If the write is not done as the first register write, the transmitter will revert to SiI9020 Tx Compatible Mode register set operation; the TPI registers will not be accessible. Refer to Appendix A for details.

SiI9022A/9024A/9136/9334 Tx only. These devices require transmitter source termination to be enabled manually during initialization. After powering up the transmitter, the host should write the following sequence to enable source termination.

### Servicing a Hot Plug Event

The host must recognize and handle Plug and Unplug events either by polling or interrupts as described in the Hot Plug Management section. Once a Plug event has been confirmed, the host follows the sequence below.

| Step | Function                                            | Registers<br>Involved   | See<br>page | Details                                                                                                                                                                                                                                                                                                      |  |  |
|------|-----------------------------------------------------|-------------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 1    | Host reads<br>EDID and sets<br>interface type       | 0x1A                    | 26          | host $\rightarrow$ Tx $\rightarrow$ Monitor: Use DDC to access EDID.<br>Host uses TPI 0x1A to request access to the DDC bus; scans EDID and reads video information, audio descriptors, and HDMI signature; then writes to TPI 0x1A to set interface type detected (HDMI or DVI) and to release the DDC bus. |  |  |
| 2    | Host enables<br>bridge CEC<br>operation             | CTRL                    | 60          | For Mobile HD Link devices only. Refer to Appendix B.                                                                                                                                                                                                                                                        |  |  |
| 3    | Host sends video and audio                          |                         |             | host → Tx: Begin transmitting video and audio streams.                                                                                                                                                                                                                                                       |  |  |
| 4    | Host sets video format and resolution               | 0x00-0x0A               | 12          | host → TPI: Set the VMode and Format registers.  Writing VMode optimizes the operation of the internal logic for the particular speed selected. Expansion and compression are set in the Input and Output Format registers.                                                                                  |  |  |
| 5    | Host sets<br>AVI InfoFrame                          | 0x0C-0x19               | 24          | host → TPI: Set AVI InfoFrame.  For an HDMI sink, write the AVI InfoFrame registers (0x0C-0x19). For a DVI sink, these registers must be cleared.                                                                                                                                                            |  |  |
| 6    | Host optionally selects YC Mux mode                 | 0x60                    | 19          | host → TPI: Set YC Mux Mode if needed.  Except for SiI9334 and SiI9136, any time TPI 0x19 is written, TPI 0x60[5] will be reset to its default state and must be explicitly restored to enable YC Mux (one- to two-data-channel de-mux) mode.                                                                |  |  |
| 7    | Host optionally configures Embedded Sync Extraction | 0x63<br>w/<br>0x60[7]=1 | 23          | host → TPI: Define parameters for embedded sync method Any time TPI 0x19 is written, TPI 0x63 will be reset to its default state and must be explicitly restored.                                                                                                                                            |  |  |
| 8    | Host sets audio mode                                | 0x1F-0x28               | 29          | host → TPI: Host parses audio descriptors from EDID, then sets audio configuration using capabilities information found.                                                                                                                                                                                     |  |  |
| 9    | Host enables video output                           | 0x1A                    | 26          | host $\rightarrow$ TPI: Enable TMDS Output.<br>Write TPI $0x1A[4] = 0$ .                                                                                                                                                                                                                                     |  |  |
| 10   | Host chooses<br>pixel repetition<br>rate            | 0x08                    |             | host $\rightarrow$ TPI: Select pixel repetition rate. Except for SiI9334 and SiI9136, this setting must always be made <i>after</i> changing 0x1A[4] from 1 to 0.                                                                                                                                            |  |  |
| 11   | TPI looks for<br>sink HDCP<br>capability            |                         |             | TPI → Monitor: HDCP read of Bksv, Bcaps from Rx.  This process happens without host intervention, triggered by the enabling of the TMDS output. This step occurs for HDCP-capable transmitters only, and can take up to 2 seconds to complete depending on sink readiness.                                   |  |  |

After configuration, the chip must be explicitly commanded to enter active (D0) mode as noted above. Video, audio, and interrupt settings can also be changed after entering D0 state, but changing the audio input selection may cause disturbances in output video and audio streams. Refer to the Transmitter Power State Register section for information on entering various power states.

### **Changing Video Modes**

Switching input video or audio modes requires a resolution change sequence. Note that if not using AV Mute, the host must **disable** HDCP before changing video modes. Otherwise, the disruption in video could break authentication at the receiver.

| Step | Details                                                                                                                                                                                                     |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | host → TPI: Blank the Display (optional). Write 0x1A[3] = 1 to send an AV Mute control packet to blank the sink device. Wait at least 128ms to allow control InfoFrames to pass through to the sink device. |
| 2    | host → TPI: Prepare for Resolution Change. Write 0x1A[4] = 1 to start the resolution change process.                                                                                                        |
| 3-10 | Same as steps 3-10 in "Servicing a Hot Plug Event".                                                                                                                                                         |
| 11   | host $\rightarrow$ TPI: Enable Display (optional).<br>Write $0x1A[3] = 0$ to un-blank the sink device.                                                                                                      |

### **HDCP Authentication and Encryption**

The hardware takes control of the DDC bus during HDCP operation. Refer to the section on p. 26 for limitations on using the DDC bus while HDCP is enabled.

| Step | HDCP-Capable Transmitter Details                                                                                                |
|------|---------------------------------------------------------------------------------------------------------------------------------|
| 1    | host ← TPI: HDCP available? (TPI 0x30 for chip availability, TPI 0x29[1] for Sink availability)                                 |
| 2    | host ← TPI: Read Aksv (TPI 0x36 group) and Bksv (TPI 0x2B group) for verification purposes (check each for 20 '1's and 20 '0's) |
| 3    | host → TPI: Request link security (TPI 0x2A)                                                                                    |
| 4    | Tx → Rx: Authenticate local link, authenticate repeater link, start link integrity check                                        |
| 5    | host ← TPI: Await "link secure" status (TPI 0x29)                                                                               |
| 6    | host → Tx: Send secure content,                                                                                                 |
| 7    | host ← TPI: Periodically verify "link secure" status (TPI 0x29)                                                                 |

### **HDCP Revocation Check**

| Step | HDCP-Capable Transmitter Details                                                                                          |
|------|---------------------------------------------------------------------------------------------------------------------------|
| 1    | host ← TPI: Repeater attached? (TPI 0x29)                                                                                 |
| 2    | host ← TPI: Extended link (through repeater) secure? (TPI 0x29)                                                           |
| 3    | host ← TPI: assert "Interrupt Control Received 1st Byte of KSV" (TPI 0x3E[1])                                             |
| 4    | host ← TPI: read "Number of bytes in KSV FIFO" (TPI 0x41[4:0])                                                            |
| 5    | host → TPI: Prepare to read KSV list (use Req/Gnt, TPI 0x1A)                                                              |
| 6    | host ← Monitor: Read bytes of KSV list in FIFO (TPI 0x42)                                                                 |
| 7    | host → TPI: Select V* value to read (TPI 0x31)<br>host ← TPI: Read V* value (TPI group 0x32–35)<br>Repeat until finished. |
| 8    | host: Calculate V value from repeater information and KSV lists read, and compare with V* for a match.                    |
| 9    | host: Check for revoked keys.                                                                                             |

# **General Programming Registers**

The TPI register set in transmitter applications provides access to data structures through the following register groups.

- Identification
- Video Mode
- Audio Configuration
- Power State Management
- HDCP
- Interrupt Service
- CTRL Bus (Mobile HD Link devices only described in Appendix B)

Figure 2 illustrates how the TPI subsystem presents a register interface of several local configuration and operational register groups to the host. The example shows an HDCP-capable transmitter; the logic for a non HDCP-capable transmitter is similar, but omits the HDCP blocks.



Figure 2. Transmitter TPI Register Interface to Host

The sections below describe the interaction required by the host to set up and operate the HDMI platform.

### **Important Notes**

These notes are mentioned elsewhere but are repeated here for clarity.

- 1. After a hardware reset, it is necessary to enter TPI mode. Write device address 0x72, register offset 0xC7 = 0x00 to enter TPI mode.
- 2. Once in TPI mode, all TPI registers referenced are accessed at  $I^2C$  device address 0x72.

### **Identification**

The ID registers return the device ID and TPI revision ID. The ID registers are listed in Table 4. HDCP-capable and non HDCP-capable transmitters are distinguishable only by reading the HDCP revision register (TPI 0x30).

Access. These registers are accessed as single bytes.

Table 3. TPI Identification Registers (RO)

| Offset | Bit 7      | Bit 6                                                      | Bit 5 | Bit 4 | Bit 3            | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|--------|------------|------------------------------------------------------------|-------|-------|------------------|-------|-------|-------|--|--|--|
| 0x1B   |            |                                                            |       |       | ce ID            |       |       |       |  |  |  |
|        |            | Refer to Table 4                                           |       |       |                  |       |       |       |  |  |  |
| 0x1C   |            | Device Production Revision ID revision level (major.minor) |       |       |                  |       |       |       |  |  |  |
|        |            | Refer to Table 4                                           |       |       |                  |       |       |       |  |  |  |
| 0x1D   | TPI Scheme |                                                            |       |       | sion level (majo |       |       |       |  |  |  |
|        | 0=Hardware | 0=Hardware Refer to Table 4                                |       |       |                  |       |       |       |  |  |  |
|        | (always)   |                                                            |       |       |                  |       |       |       |  |  |  |
|        | 1=Software |                                                            |       |       |                  |       | 1     |       |  |  |  |

**Table 4. Device ID Information** 

| Device            | Device ID<br>TPI 0x1B |            |            | HDCP Revision<br>TPI 0x30 |  |
|-------------------|-----------------------|------------|------------|---------------------------|--|
| SiI9022 Tx        | 0xB0                  | 0x00       | 0x00       | 0x00                      |  |
| SiI9022A Tx       | 0xB0                  | 0x02       | 0x03       | 0x00                      |  |
| SiI9024 Tx        | 0xB0                  | 0x00       | 0x00       | 0x12                      |  |
| SiI9024A Tx       | 0xB0                  | 0x02       | 0x03       | 0x12                      |  |
| SiI9136/9334 Tx   | 0xB4                  | 0x20       | 0x30       | 0x12                      |  |
| Mobile HD Link Tx | . ( )                 | Refer to A | Appendix B |                           |  |

### **Video Configuration**

Setup for the incoming video resolution at minimum requires video mode and AVI InfoFrame data. The registers below describe the interface; refer also to the source code provided with the Starter Kit.

### Video Mode

The host notifies TPI of its intended resolution through the following read/write registers.

Note: This information must be written for both HDMI mode and DVI mode operation.

### **Basic Video Mode Data**

The video host provides the video mode data listed below. TPI requires that these values be set for proper operation.

**Access.** These registers can be read or written individually or by bursts as desired. The actual write to the HDMI transmitter registers takes place only once the final byte of the burst is written.

Table 5. TPI Video Mode Data (R/W)

| Offset           | Bit 7      | Bit 6                              | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|------------------|------------|------------------------------------|-------|-------|-------|-------|-------|-------|--|--|--|
| 0x00             | PixelClock |                                    |       |       |       |       |       |       |  |  |  |
| [00]             |            | Pixel Clock / 10000 – LSB          |       |       |       |       |       |       |  |  |  |
| <b>0x01</b> [00] |            | MSB                                |       |       |       |       |       |       |  |  |  |
| 0x02             |            | VFreq                              |       |       |       |       |       |       |  |  |  |
| [00]             |            | Vertical Frequency in Hz – LSB     |       |       |       |       |       |       |  |  |  |
| <b>0x03</b> [00] | MSB        |                                    |       |       |       |       |       |       |  |  |  |
| <b>0x04</b> [00] |            | Pixels Total Pixels per line – LSB |       |       |       |       |       |       |  |  |  |
| <b>0x05</b> [00] |            | MSB                                |       |       |       |       |       |       |  |  |  |
| 0x06             |            | ( )                                |       | Li    | nes   |       |       |       |  |  |  |
| [00]             |            | Total Lines – LSB                  |       |       |       |       |       |       |  |  |  |
| 0x07             | MSB        |                                    |       |       |       |       |       |       |  |  |  |
| [00]             |            |                                    |       |       |       |       |       |       |  |  |  |

PixelClock. The logic uses this value to configure the internal PLL circuitry for optimal operation at the incoming frequency.

**VFreq.** For the SiI9136, SiI9334, and SiI9232 transmitters with HDCP, the logic uses this value to correctly time HDCP authentication operations that are based on frame rates.

The input bus clocking format, along with clocking rate and edge, are specified in this register. The video host also indicates the pixel repetition factor here. Refer to the Format Matching section below for an example.

Access. This register is accessed as a single byte. Except for the SiI9136/9334 Tx, it must be written after TPI 0x1A[4] is set to 0, also any time TPI 0x1A[4] goes from 1 to 0, TPI 0x08[3:0] will be reset to their default state.

| Offset | Bit 7          | Bit 6             | Bit 5          | Bit 4       | Bit 3                                    | Bit 2     | Bit 1     | Bit 0 |  |
|--------|----------------|-------------------|----------------|-------------|------------------------------------------|-----------|-----------|-------|--|
| 0x08   |                |                   |                | Input       | BusFmt                                   |           |           |       |  |
| [60]   | TClk           | :Sel <sup>1</sup> | Input Bus      | Edge        |                                          | PR3:0     |           |       |  |
|        | Ratio of outpu | t TMDS clock      | Select         | Select      | ect Pixel Repetition Factor <sup>2</sup> |           |           |       |  |
|        | to input v     | ideo clock        | 0 – half-      | 0 – Falling | 0000 – Pixel data is not replicated      |           |           | d     |  |
|        | 00 –           | x0.5              | pixel wide     | edge        | 0001 – Pixels are sent two times each    |           | nch       |       |  |
|        | 01 - x1        | (default)         | 1 – full pixel | 1 – Rising  | 0011 – Pixels are sent four times each   |           |           | ach   |  |
|        |                | - x2              | wide           | edge        |                                          | All other | rs – Rsvd | 1     |  |
|        | 11 -           | - x4              | (default)      |             |                                          |           |           |       |  |

Table 6. TPI Input Bus and Pixel Repetition Data (R/W)

#### Note

- 1. TClkSel is not available here on the SiI9022 or SiI9024 Tx (non "A" versions). The bits default to 00 in those parts.
- 2. PR3:0 are cleared whenever TPI 0x1A[4] goes from 1 to 0.

**Input Bus Select.** The input data bus can be either one pixel wide or ½ pixel wide. The bit defaults to 1 to select full pixel mode. In ½ pixel mode, the full pixel is brought in on two successive clock edges (one rising, one falling). All parts support 24-bit full-pixel and 12-bit half-pixel input modes.

The SiI9136/9334 Tx additionally supports 30- and 36-bit full-pixel and 15-, 18-, and 24-bit half-pixel input modes. The corresponding color depth is selected at TPI 0x09[7:6].

**Edge Select.** Input data is latched on the selected rising or falling clock edge. For  $\frac{1}{2}$  pixel mode, this bit indicates when = 0 that data present at the falling edge is latched first, and when = 1, data present at the rising edge is latched first. The high-order bits are latched first.

**TClkSel.** If the video host drives in data using anything other than a 1:1 ratio of input clock speed to TMDS clock speed, the host must program the clock multiplier logic. Refer to the Format Matching section below for an example.

→ Exception. Most devices can access these bits directly as shown in Table 6. For SiI9022/SiI9024 (non "A" version) devices, set the clock management subsystem to the correct ratio using the following sequence.

Table 7. TPI Frequency Multiplication Ratio (R/W)

|                                                                             | Bit 7                    | Bit 6                          | Bit 5                                                   | Bit 4 | Bit 3 | Bit 2             | Bit 1 | Bit 0 |
|-----------------------------------------------------------------------------|--------------------------|--------------------------------|---------------------------------------------------------|-------|-------|-------------------|-------|-------|
| Internal<br>Register<br>available<br>at 0xBE<br>when:<br>0xBC=01<br>0xBD=82 | Rsvd – write<br>as read. | to input vi<br>00 –<br>01 – x1 | t TMDS clock<br>ideo clock<br>x0.5<br>(default)<br>- x2 |       | Rs    | vd – write as rea | ad.   |       |

### **Format Matching**

For certain combinations of video input clock frequency and audio sampling rate, the HDMI transmitter must use a higher multiple of the input pixel clock when sampling the S/PDIF input.

Set PR3:0 to reflect the pixel replication factor of the input data stream so that it is properly decoded. TClkSel indicates the factor by which the input clock (IDCK) must be multiplied to yield the output clock frequency. These settings ensure that the output clock can provide sufficient bandwidth for multi-channel audio data on an HDMI link. The pixel replication count bits in the AVI InfoFrame Packet must be accurate. Refer to Table 8 for an example based on the 480p instance cited in section 7.3 of the HDMI Specification version 1.3a.

| Input<br>Clock | Write to TPI 0x01:00 | Audio Mode & max f <sub>s</sub> | TPI 0x08<br>PR3:0<br>Pixel rep. | YC Mux Mode<br>(TPI 0x60[5]) | (refer to previous | Output<br>Pixel<br>Rep. | Resulting<br>TMDS Link<br>Clock | AVI InfoFrame<br>Packet Byte 5<br>bits PR3:PR0 |
|----------------|----------------------|---------------------------------|---------------------------------|------------------------------|--------------------|-------------------------|---------------------------------|------------------------------------------------|
|                | (decimal)            |                                 |                                 |                              | page)              |                         |                                 |                                                |
| 54MHz          | 5400                 | 8 ch, 96kHz                     | 0b01 (2x)                       | 0                            | 01 (1.0)           | $2x^7$                  | 54MHz <sup>6</sup>              | 0b0001                                         |
| 54MHz          | 5400                 | 2 ch, 192kHz                    | 0b01 (2x)                       | 0                            | 00 (0.5)           | 1x                      | 27MHz                           | 0b0000                                         |
| 54MHz          | 5400                 | 8 ch, 96kHz                     | 0b00 (1x)                       | 15                           | 01                 | $2x^7$                  | 54MHz <sup>6</sup>              | 0b0001                                         |
| 54MHz          | 5400                 | 2 ch, 192kHz                    | 0b00 (1x)                       | 1 <sup>5</sup>               | 00                 | 1x                      | 27MHz                           | 000000                                         |
| 27MHz          | 2700                 | 8 ch, 96kHz                     | 0b00 (1x)                       | 0                            | 0b10 (2.0)         | $2x^7$                  | 54MHz <sup>6</sup>              | 0b0001                                         |
| 27MHz          | 2700                 | 2 ch, 192kHz                    | 0b00 (1x)                       | 0                            | 0b11 (4.0)         | 4x <sup>8</sup>         | 108MHz                          | 0b0011                                         |
| 27MHz          | 2700                 | 8 ch, 48kHz                     | 0b00 (1x)                       | 0                            | 0b01 (1.0)         | $1x^9$                  | 27MHz                           | 0b0000                                         |

Table 8. 480p Mode Format Matching Example

#### Notes

- 1. Input Clock (IDCK) and the TMDS Link Clock must be within the min/max range for the HDMI transmitter.
- 2. For proper decoding, set PR3:0 to reflect the pixel replication factor of the input data stream.
- 3. TClkSel selects the factor by which the input clock must be multiplied to give output clock frequency.
- 4. There is only one pixel per 27 MHz clock cycle, so each must be replicated.
- 5. When YCbCr 4:2:2 data is multiplexed onto a single channel, the input clock must be doubled.
- 54 MHz is necessary so that the blanking intervals have sufficient bandwidth to carry the 8-channel audio data sampled at frequencies up to 96 kHz.
- 7. Because the output clock has been doubled, pixels must be replicated.
- 8. Illustrates 4x pixel replication on output.
- 9. 27 MHz input clock provides sufficient bandwidth for 8-channel audio data sampled at frequencies 48 kHz and below. Refer to the *HDMI Specification*.
- 10. Bits PR0:PR3 of Byte 5 of the AVI InfoFrame packet indicate to the HDMI sink how many repetitions of each unique pixel are transmitted. Refer to the *CEA-861-E Specification*.

These settings ensure that the output clock provides sufficient bandwidth for multi-channel audio data on an HDMI link (25 MHz minimum).



Normal IDCK: Edge A: Cb + ½ Y; Edge B: Cr + ½ Y; Edge A: Cb + ½ Y; Edge B: Cr + ½ Y,...

Figure 3. Input Bus Diagram for Different Formats

### **Input and Output Format**

InputFormat and OutputFormat are used by the host to specify the data format and range. At a reset event, the chip defaults set input and output to be full-range RGB.

To set these registers, the host should read the EDID to determine whether the sink is DVI or HDMI, and what its preferred output format is. Once written, the selection remains until overwritten or until the next reset event.

**Input Color Space / Output Format.** These bits should be set as needed. Note that the settings made to these bits do not take effect until the AVI InfoFrame registers are programmed, so that any color space change can be synchronized to the color settings specified in the InfoFrame (avoiding temporarily green or pink images).

Range Compression. Range compression is enabled when RGB input and YCbCr output conversion is selected.

Range Expansion. Range expansion is enabled when YCbCr input and RGB output conversion is selected

**Range Override.** Range Expansion is associated with the Input Format; the Range bits either force expansion (01) or block it (10). Range Compression is associated with the Output Format; the Range bits either block compression (01) or force it (10).

**Input Color Depth.** This setting selects the incoming bus width to allow for proper handling on output. Note that only two YCbCr input bus widths, 8-bit and 12-bit, are possible. For 4:2:2 inputs 9, 10, or 11 bits wide, the host should set 0x09[7:6]=11 (12 bits), and drive unused bits of the video stream to 0.

**Black Mode.** This setting disables the video data input bus, forcing the video output to black (as long as valid video clock and control inputs are still available). This setting should not be used when HDCP is enabled, as the screen will show snow.

**Access.** These registers can be accessed individually or by bursts as desired. For writes, the actual write to the HDMI transmitter logic takes place only once the final byte of the burst write to TPI 0x0C-19 occurs (refer to Input Color Space / Output Format note above).

Table 9. TPI AVI Input and Output Format Data (R/W)
Bit 6 Bit 5 Bit 4 Bit 3 Bit 2

| Offset | Bit 7                                                  | Bit 6                                                          | Bit 5                                                                       | Bit 4                                                                           | Bit 3                                                 | Bit 2                 | Bit 1                                            | Bit 0                                                   |
|--------|--------------------------------------------------------|----------------------------------------------------------------|-----------------------------------------------------------------------------|---------------------------------------------------------------------------------|-------------------------------------------------------|-----------------------|--------------------------------------------------|---------------------------------------------------------|
| 0x09   |                                                        |                                                                |                                                                             | Inputl                                                                          | Format                                                |                       |                                                  |                                                         |
| [00]   | 1                                                      | or Depth <sup>1</sup><br>8-bit                                 | Rs                                                                          | Rsvd Video Range Expan                                                          |                                                       |                       | Input Color Space                                |                                                         |
|        | 01 - 16-bit <sup>2</sup><br>10 - 10-bit (10/12-bit un- |                                                                |                                                                             |                                                                                 | 00 – Auto-selected by [1:0]<br>01 – On<br>10 – Off    |                       | 00 – RGB<br>01 – YCbCr 4:4:4<br>10 – YCbCr 4:2:2 |                                                         |
|        | dithered for 11 – 12-bit (                             | 4:2:2 mode)<br>(10/12-bit di-<br>or 4:2:2 mode)                |                                                                             |                                                                                 | 11 – Rsvd                                             |                       | 11 – Black Mode <sup>3</sup>                     |                                                         |
| 0x0A   | ,                                                      | ·                                                              |                                                                             | Output                                                                          | Format                                                |                       |                                                  |                                                         |
| [00]   | 00 – 8-bit<br>for 4:2:<br>01 –<br>10 –                 | lor Depth <sup>2</sup> (also used 2 mode) 16-bit 10-bit 12-bit | Dither from Input Depth to Output Depth <sup>2</sup> 0 – Disable 1 – Enable | Color Space<br>Standard<br>0 – BT.601<br>conversion<br>1 – BT.709<br>conversion | Video Range<br>00 – Auto-sele<br>01 –<br>10 –<br>11 – | ected by [1:0] Off On | 00 -<br>01 - YC<br>10 - YC                       | Format<br>RGB<br>bCr 4:4:4<br>bCr 4:2:2<br>(same as 00) |

### Notes

- 1. These bits were formerly described as Extended and Dither.
- 2. Applies only to devices capable of Deep Color output (SiI9136/9334 Tx). See notes below.
- 3. For the SiI9136/9334, the blanking levels for Black Mode vary based on color space and video range. Before setting TPI 0x09[1:0] = 3, set the TPI Video Mute Registers, TPI 0x4A through TPI 0x4F.

**Deep Color Operation (SiI9136/9334 Tx only).** Deep color settings can be used where supported by the HDMI sink device. The following additional configuration is required.

**General Control Packet** – Deep color settings require the General Control Packet to be sent once per video field with the correct PP and CD information. This must be enabled by software via TPI Deep Color Packet Enable Register 0x40[2] = 1, enable transmission of the GCP packet.

Output Color Depth – This setting selects the color depth for the HDMI output stream, and also selects the corresponding HDMI protocol handling. It should be left at 8-bit for YCbCr 4:2:2 modes, as well as for any non deep-color mode of operation. Unlike the other bits in this register, any output color depth setting change takes place immediately and is not dependent on a write to the AVI InfoFrame registers.

**Note 1:** Selecting any deep color output mode is done directly through TPI 0x0A[7:6]. However, if it is later necessary to switch back to 8-bit color depth, switch to 16-bit deep color first, and then to 8-bit color depth.

Dither from Input Depth to Output Depth – When the incoming data contains greater color depth than the attached HDMI source is capable of handling, this bit can be set to dither the HDMI output based on the least significant bits of the input, and thereby achieve greater color accuracy. For example, if TPI 0x09[7:6]=01, 16-bit input depth, and TPI 0x0A[7:6]=10, 10-bit output depth, setting 0x0A[5]=1 will dither from 16-bit input to 10-bit output depth.

#### Silicon Image, Inc.

**Video Mute Operation (SiI9136/9334 Tx only).** The Black Level data is related to the Video Input Mode (RGB / YCbCr 444, YCbCr422) and Input width (8, 10, 12, 16) and programmable.

Table 10. TPI Video Mute Registers (R/W)

| Offset | Bit 7             | Bit 6                         | Bit 5 | Bit 4          | Bit 3         | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|--------|-------------------|-------------------------------|-------|----------------|---------------|-------|-------|-------|--|--|--|
|        |                   |                               |       | Cb component / | Blue componen | t     |       |       |  |  |  |
| 0x4A   |                   |                               |       | Cb [7:0]       | / B [7:0]     |       |       |       |  |  |  |
| 0x4B   |                   | Cb [15:8] / B [15:8]          |       |                |               |       |       |       |  |  |  |
|        |                   | Y component / Green component |       |                |               |       |       |       |  |  |  |
| 0x4C   | Y [7:0] / G [7:0] |                               |       |                |               |       |       |       |  |  |  |
| 0x4D   |                   |                               |       | Y [15:8]       | / G [15:8]    |       |       |       |  |  |  |
|        |                   | Cr component / Red component  |       |                |               |       |       |       |  |  |  |
| 0x4E   |                   | Cr [7:0] / R [7:0]            |       |                |               |       |       |       |  |  |  |
| 0x4F   |                   | Cr [15:8] / R [15:8]          |       |                |               |       |       |       |  |  |  |

For Black Level Settings:

Input 720p RGB and Output YCbCr (8 bit) a Black Level can be achieved via the following settings:

Input 720p YCbCr and Output YCbCr (8 bit) a Black Level can be achieved via the following settings:

# Output color space control (SiI9334 and SiI9136)

Since it is optional for a sink to support AV Mute packets, HDMI transmitters need to output correct blanking levels during AV Mute packets. This can be accomplished using the following sequence:

```
1) Write 0xBC=0x01
                                                 // Internal page 1
         2)
            Write 0xBD=0x4B
                                                 // Indexed register 0x4B
            Write 0xBE=Blank1
                                                    Blue/Cb channel value (MSB)
            Write 0xBD=0x4C
                                                    Indexed register 0x4B
         5)
            Write 0xBE=Blank2
                                                    Y/G channel value (MSB)
         6)
            Write 0xBD=0x4D
                                                 // Indexed register 0x4B
         7) Write 0xBE=Blank1
                                                 // Red/Cr channel value (MSB)
Blank1 value is 0x00 for full range RGB, 0x10 for limited range RGB, 0x80 for YCbCr.
Blank2 value is 0x00 for full range RGB, 0x10 for limited range RGB and YCbCr.
```

### **Input Setup Operations**

Programming setup for the device is straightforward. A typical startup configuration sequence is shown below.

### Write:

### **Sync Generation Options**

For input video modes that do not provide explicit HSYNC, VSYNC, and/or DE signals, the transmitter logic offers two methods for sync signal generation:

- DE Generation (when explicit HSYNC and VSYNC signals are provided)
- Sync Extraction (when incoming video uses the ITU 656 method for embedding sync information).

The register sets for both modes overlap, so only one can be accessed at a time. However, by toggling between the two groups, features from both can be intermixed.

The dual data paths are shown in Figure 4, with the path for embedded sync extraction highlighted. When decoding syncs from the embedded sync stream, the DE Generator block should be disabled through TPI 0x63[6].



Figure 4. Transmitter Video Data with Sync Decoding

### Silicon Image, Inc.

The registers available at 0x62–0x6F depend on the setting of TPI 0x60[7].

- Setting TPI 0x60[7] = 0 selects external sync and access to the DE Generator registers. The DE signal can be generated internally and sent over TMDS if TPI 0x62–6D are set and then TPI 0x63[6] is set to 1.
- Setting TPI 0x60[7] = 1 allows access to the Embedded Sync Extraction registers. The DE, HSYNC, and VSYNC signals can then be extracted and sent over TMDS if TPI 0x62–69 are set and then TPI 0x63[6] is set to 1.

Features from both groups can be enabled together, by enabling the features of each group with TPI 0x60[7] set appropriately.

Access. These registers are accessed as single bytes or as part of a burst.

→ Important Note: TPI 0x60 must be written after the AVI InfoFrame is set. Any time TPI 0x19 is written, TPI 0x60[5] will be reset to its default state. The SiI9136/9334 does not require TPI 0x60 to be written after the AVI InfoFrame.

| Offset | Bit 7        | Bit 6 | Bit 5        | Bit 4           | Bit 3            | Bit 2          | Bit 1          | Bit 0           |  |
|--------|--------------|-------|--------------|-----------------|------------------|----------------|----------------|-----------------|--|
| 0x60   |              |       | S            | Sync Generation | Control Registe  | er             | • (            | •               |  |
| [04]   | Sync Method  | Rsvd  | YC Mux       | Invert Field    | Rsvd             | DE_ADJ#        | F2VADJ         | F2VOFST         |  |
|        | 0 – External |       | Mode         | Polarity        |                  | 0 – Enable     | Adjust VBIT    | Adjust VBIT     |  |
|        | 1 – Embedded |       | One- to two- | 0 – Leave       |                  | (recom-        | to VSYNC per   | to VSYNC if     |  |
|        |              |       | data-channel | bit as is       |                  | mended)        | bit [0]        | bit $[1] = 1$   |  |
|        |              |       | de-mux       | 1 – Invert      |                  | 1 – Disable    | 0 – Disable    | 0-Decrement     |  |
|        |              |       | 0 – Disable  | field bit       |                  | (default)      | (default)      | by 1            |  |
|        |              |       | 1 – Enable   |                 |                  |                | 1 – Enable     | 1 – Increment   |  |
|        |              |       |              |                 |                  |                |                | by 1            |  |
| 0x61   |              |       | Video        | Sync Polarity D | etection Registe | r (RO)         |                |                 |  |
| [00]   | Rsvd         | Rsvd  | Rsvd         | Rsvd            | Rsvd             | Interlace      | Input VSYNC    | Input HSYNC     |  |
|        |              | . (1  | X            |                 |                  | Mode detected  | 1 3            | polarity        |  |
|        |              |       |              | $c(\cdot)$      |                  | 0 – non        | detected       | detected        |  |
|        | •.           |       |              | X               |                  | interlaced     | U              | 0 – active high |  |
|        |              |       |              |                 |                  | 1 – interlaced | (leading edge  | (leading edge   |  |
|        |              | 1     |              |                 |                  |                | rises)         | rises)          |  |
|        |              |       |              | . (1            |                  |                | 1 – active low | 1 – active low  |  |
|        |              |       |              |                 |                  |                | (leading edge  | (leading edge   |  |
|        |              |       |              |                 |                  |                | falls)         | falls)          |  |

Table 11. Sync Register Configuration and Sync Monitoring Registers

**DE\_ADJ**# enables detection circuits to locate the position of VSYNC relative to HSYNC and only include HSYNC edges that are greater than ¾ lines from VSYNC in the line count for DE\_TOP. Clearing this bit enables the function and is recommended for normal operation. Setting it high disables VSYNC adjustments and is not a recommended setting.

**F2VADJ** adjusts the VBIT\_TO\_VSYNC value during field 2 of an interlace frame; **F2VOFST** sets the direction of adjustment (increment or decrement by 1).

**Invert Field Polarity.** The Invert Field Polarity bit is used when the 656 Flag Bit is opposite the standard polarity for Field1 and Field2. Inverting polarity causes the sync extraction to format HSYNC and VSYNC properly based on the 'F' bit. In embedded sync mode, the transmitter does not detect 'even' from 'odd' field, except based on the setting of the 'F' bit. With explicit syncs, the transmitter simply encodes HSYNC and VSYNC across the HDMI/TMDS link without regard for field sequence.

### **YC Mux Mode**

When YCbCr 4:2:2 data is multiplexed onto a single channel (YC Mux mode), the input clock rate from the host must be doubled. The one- to two-data-channel de-mux feature is used to decode the incoming data accordingly. When using YC Mux mode (TPI 0x60[5]=1), the input data can be additionally manipulated using the register controls provided below.

| Table 12 | . TPI YC | Input Mod | e Select <sup>1</sup> | ( <b>R</b> / <b>W</b> ) |
|----------|----------|-----------|-----------------------|-------------------------|
|----------|----------|-----------|-----------------------|-------------------------|

| Offset           | Bit 7                                                                                                       | Bit 6                                                                                  | Bit 5 | Bit 4 | Bit 3                                        | Bit 2                                         | Bit 1                                                                                                                 | Bit 0                                                   |
|------------------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|-------|-------|----------------------------------------------|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|
| <b>0x0B</b> [00] | Swap MSB<br>and LSB<br>within each<br>data channel. <sup>4</sup><br>("A" only)<br>0 – Disable<br>1 – Enable | Video Input<br>DDR Select <sup>2</sup><br>0 – Lower<br>12 bits<br>1 – Upper<br>12 bits | Rsvd  | Rsvd  | Non Gap<br>Mode<br>0 – Disable<br>1 – Enable | 001 -<br>010 -<br>011 - YC 8-<br>100 - YC 24- | Input Mode Sel 2000 – YC norma YC channel data - YC 8-bit DDR -bit DDR input, swap -bit input in consother values = R | al<br>a swap<br>input<br>channel data<br>secutive order |

### Notes

- 1. This register is not available in the SiI9022 and SiI9024 Tx (non "A" revisions).
- 2. The SiI9136/9334 Tx does not support this option.
- 3. The SiI9136/9334 Tx supports only the 000 and 001 options. The SiI9136/9334 Tx YC channel data swap (YC Input Mode Select, bits[2:0]) control does not require YC Mux Mode Channel swapping to be enabled (TPI 0x60[5]=1).
- 4. The Sil9136/9334 Tx bit swapping (Swap MSB and LSB within each data channel, bit [7]) control does not require YC Mux Mode Channel swapping to be enabled (TPI 0x60[5])=1).

**Swap MSB and LSB** swaps the most significant and least significant bytes of the incoming data. This feature is not supported in YC Mux Mode.

Video Input DDR Select chooses the pins on which 12-bit DDR video will arrive.

- Lower 12 bits D11:0 are the default input path.
- Upper 12 bits D23:12 are available as an optional input path, for the SiI9022A and SiI9024A devices only.

**YC Input Mode Select** adds new input bus formats when using YC Input modes. Refer to SiI9022A/SiI9024A HDMI Transmitter Data Sheet (SiI-DS-1053) for details.

- "YC channel data swap" reverses the order of data on the 1<sup>st</sup> and 2<sup>nd</sup> clocks, normally C-then-Y, to Y-then-C.
- "YC 8-bit DDR input" enables double-data-rate clocking, so that the C data comes on the rising (or falling) clock edge, and Y data on the falling (or rising) clock edge.
- "YC 8-bit DDR input, channel data swap" enables both DDR and swap, so that the Y data comes on the rising (or falling) clock edge, and C data on the falling (or rising) clock edge.
- "YC 24-bit input in consecutive order" enables full data input of all 24 bits on a single clock edge.

## **DE Generator Register Set**

The DE Generator registers are accessible only when TPI 0x60[7] = 0.

The transmitter provides an explicit sync DE generator that allows the Data Enable (DE) signal, required to be encoded in the TMDS output, to be derived from the incoming HSYNC and VSYNC signals. When programmed through TPI registers 0x62–6D, the output DE is generated based on the values in the DE generator registers and the arrival times of the HSYNC and VSYNC pulses from the video source. These registers are used only for DE generation and do not affect HSYNC or VSYNC.

The registers are shown diagrammatically in Figure 5. The vertical sync pulse (VSYNC) occurs in the top area of the frame, before the active video area. The active (leading) edge is shown with an arrow. The horizontal sync pulse (HSYNC) occurs every line before the active video area during the DE\_DLY time. The active (leading) edge of HSYNC is shown with an arrow. (Note that VSYNC and HSYNC widths are not shown to scale.)



Figure 5. DE Generator Measurements

In the following definitions, 'pixels' is used to mean 'unique pixels'. The counts in the DE Generator registers, if expressed in 'pixels,' are counted according to the original clock, even if that original input clock is multiplied internal to the chip. For example, a 480i field will contain 720 unique pixels per line in the active video area, even when the clock is multiplied to 1440 clock cycles per active video time.

Default. The DE Generator defaults to 'disabled' after reset.

Access. These registers can be read or written individually or by bursts as desired. All are read/write except as noted.

| Offset           | Bit 7            | Bit 6                 | Bit 5                    | Bit 4            | Bit 3           | Bit 2             | Bit 1                                            | Bit 0 |  |  |
|------------------|------------------|-----------------------|--------------------------|------------------|-----------------|-------------------|--------------------------------------------------|-------|--|--|
| 0x62             |                  |                       |                          | DE_DI            | Y[7:0]          |                   |                                                  |       |  |  |
| [00]             |                  | Г                     |                          | Г                |                 | ,                 |                                                  |       |  |  |
| 0x63             | Rsvd             | DE                    | VSYNC                    | HSYNC            | Rsvd            | Rsvd              | DE_DLY[9:8]                                      |       |  |  |
| [00]             |                  | Generator             | Polarity:                | Polarity:        |                 |                   |                                                  |       |  |  |
|                  |                  | 0 – Disable           | 0 – Positive             | 0 – Positive     |                 |                   |                                                  |       |  |  |
|                  |                  | 1 – Enable            | (leading                 | (leading         |                 |                   |                                                  |       |  |  |
|                  |                  |                       | edge rises)              | edge rises)      |                 |                   |                                                  |       |  |  |
|                  |                  |                       | 1 – Negative<br>(leading | 1 – Negative     |                 |                   |                                                  |       |  |  |
|                  |                  |                       | edge falls)              | (leading         |                 |                   |                                                  |       |  |  |
| 0.64             |                  |                       | edge fails)              | edge falls)      |                 |                   |                                                  |       |  |  |
| 0x64             | Rsvd DE_TOP[6:0] |                       |                          |                  |                 |                   |                                                  |       |  |  |
| [00]             |                  |                       |                          |                  |                 |                   |                                                  |       |  |  |
| 0x65             | Rsvd             |                       |                          |                  |                 |                   |                                                  |       |  |  |
| [00]             |                  |                       |                          |                  |                 |                   |                                                  |       |  |  |
| 0x66             |                  |                       |                          | DE_CN            | JT[7:0]         |                   |                                                  |       |  |  |
| [00]             |                  |                       | <del></del>              |                  |                 |                   |                                                  |       |  |  |
| 0x67             |                  | Rsvd                  |                          | 0                | 10              | DE_CNT[12:8]      |                                                  |       |  |  |
| [00]             |                  |                       |                          | X - X            |                 |                   |                                                  |       |  |  |
| <b>0x68</b> [00] |                  | DE_LIN[7:0]           |                          |                  |                 |                   |                                                  |       |  |  |
| 0x69             |                  | Rs                    | ···d                     |                  |                 | DE_LI             | V(11.0)                                          |       |  |  |
| [00]             |                  | KS                    | vu                       |                  |                 | DE_LII            | N[11:0]                                          |       |  |  |
| 0x6A             | П                | _RES[7:0] (RO)        | Magazzas the             | tima batuyaan tu | o USVNC activ   | in adaps. Unit of | maagura is niva                                  | ıla   |  |  |
| [00]             | 11               | _KES[7.0] (KO)        | - Weasures the           | time between tw  | 70 HS THE activ | ve edges. Unit of | ineasure is pixe                                 | 15.   |  |  |
| 0x6B             | D.               | rvd.                  |                          |                  | H DECI1         | 3.81 (PO)         | <del>)                                    </del> |       |  |  |
| [00]             | IX.              | Rsvd H_RES[13:8] (RO) |                          |                  |                 |                   |                                                  |       |  |  |
| 0x6C             | V                | _RES[7:0] (RO)        | – Measures the           | time between ty  | vo VSYNC acti   | ve edges. Unit o  | f measure is line                                | es.   |  |  |
| [00]             |                  |                       |                          |                  | 0 7             |                   |                                                  |       |  |  |
| 0x6D             |                  | Rs                    | vd                       |                  |                 | V_RES[1           | 1:8] (RO)                                        |       |  |  |
| [00]             |                  | ( 1                   |                          |                  |                 |                   |                                                  |       |  |  |
|                  |                  |                       |                          |                  |                 |                   |                                                  |       |  |  |

Table 13. Explicit Sync DE Generator Registers (TPI 0x60[7] = 0)

**DE\_DLY[9:0]** set the width of the area to the left of the active display. Unit of measure is pixels. This register should be set to the sum of (HSYNC width) + (horizontal back porch) + (horizontal left border), and is used only for DE generation. Valid range is 1–1023. 0 is invalid.

**HSYNC and VSYNC Polarity** bits 0x63[5:4] should be set to the polarity of the source providing the sync signals. Setting these bits does not change the polarity of HSYNC or VSYNC in the encoded TMDS output stream.

**DE\_TOP[6:0]** define the height of the area above the active display. The unit of measure is lines (HSYNC pulses). This register should be set to the sum of (VSYNC width) + (vertical back porch) + (vertical top border). Valid 1–127. 0 is invalid.

**DE\_CNT[12:0]** define the width of the active display. Unit of measure is pixels. This register should be set to the desired horizontal resolution. The DE\_CNT is 12 bits (valid values are 1 through 2047, 0 is invalid) for parts that support HDMI 1.3. The DE\_CNT is 13 bits (valid values are 1 through 8191, 0 is invalid) for parts that support HDMI 1.4, see Appendix D.

**DE\_LIN[11:0]** define the height of the active display. The unit of measure is lines (HSYNC pulses). This register should be set to the desired vertical resolution. The DE\_LIN is 11 bits (valid values are 1 through 2047, 0 is invalid) for parts that support HDMI 1.3. The DE\_LIN is 12 bits (valid values are 1 through 4095, 0 is invalid) for parts that support HDMI 1.4, see Appendix D.

**H\_RES** [13:0] and **V\_RES** [11:0] measure the time between two sync active edges and may vary slightly from one reading to the next. The values in these registers are accurate only when there are active HSYNC and VSYNC controls arriving on the video input. The H\_RES is 12 bits (valid values are 1 through 4095, 0 is invalid) for parts that support HDMI 1.3. The H\_RES is 14 bits (valid values are 1 through 16383, 0 is invalid) for parts that support HDMI 1.4, see Appendix D.

### **Embedded Sync Register Set**

The Embedded Sync Extraction registers are available only when TPI 0x60[7] = 1.

The transmitter provides logic to extract ITU 656 encoding from the video stream.

Table 14. Embedded Sync Extraction Registers (TPI 0x60[7] = 1)

| Offset           | Bit 7                  | Bit 6                                                        | Bit 5                                                                                            | Bit 4                                                                                            | Bit 3 | Bit 2 | Bit 1     | Bit 0                   |  |
|------------------|------------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-------|-------|-----------|-------------------------|--|
| <b>0x62</b> [00] | HBIT_TO_HSYNC[7:0]     |                                                              |                                                                                                  |                                                                                                  |       |       |           |                         |  |
| <b>0x63</b> [00] | Rsvd                   | Embedded Sync Extraction <sup>1</sup> 0 – Disable 1 – Enable | VSYNC Polarity: <sup>2</sup> 0 – Positive (leading edge rises) 1 – Negative (leading edge falls) | HSYNC Polarity: <sup>2</sup> 0 – Positive (leading edge rises) 1 – Negative (leading edge falls) | R     | svd   | HBIT_TO_H | ISYNC[9:8] <sup>1</sup> |  |
| <b>0x64</b> [00] | FIELD2_OFST[7:0]       |                                                              |                                                                                                  |                                                                                                  |       |       |           |                         |  |
| 0x65<br>[00]     | Rsvd FIELD2_OFST[12:8] |                                                              |                                                                                                  |                                                                                                  |       |       |           |                         |  |
| <b>0x66</b> [00] | HWIDTH[7:0]            |                                                              |                                                                                                  |                                                                                                  |       |       |           |                         |  |
| <b>0x67</b> [00] | Rsvd HWIDTH[9:8]       |                                                              |                                                                                                  |                                                                                                  |       |       |           |                         |  |
| <b>0x68</b> [00] | Rsvd VBIT_TO_VSYNC     |                                                              |                                                                                                  |                                                                                                  |       |       |           |                         |  |
| <b>0x69</b> [00] | Rs                     | svd                                                          |                                                                                                  | ζO)                                                                                              | VWI   | DTH   |           |                         |  |

### Note

- 1. The Embedded Sync Mode information at TPI 0x63 is always reset to its default disabled state whenever AVI InfoFrame register TPI 0x19 is written. Therefore, if embedded sync video input is being used, TPI 0x63 must be re-written after any write to TPI 0x19.
- 2. Vsync and Hsync Polarity settings are only available in the Embedded Sync Extraction Registers for the Sil9136/9334. To change Vsync and Hsync Polarity settings on parts other than the Sil9136/9334 use the following sequence:
  - a. Switch to Explicit Sync DE Generator configuration (TPI 0x60[7]=0).
  - b. Modify Vsync and Hsync polarity (TPI 0x63[5:4]).
  - c. Switch back to Embedded Sync Extraction configuration (TPI 0x60[7]=1).

The settings described below are useful only when the input video uses 656 encoded syncs. 0 is an invalid setting for all these parameters.

**HBIT\_TO\_HSYNC[9:0]** create HSYNC pulses. Set register to the delay from the detection of an EAV sequence (H bit change from 1 to 0) to the active edge of HSYNC. Unit of measure is pixels. Valid 1-1023.

**FIELD2\_OFST[11:0]** determine VSYNC pixel offset for the odd field of an interlaced source. Set this to half the number of pixels/line. Valid 1–4095.

**HWIDTH[9:0]** set the width of the HSYNC pulses. Set the register to the desired HSYNC pulse width. Unit of measure is pixels. Valid 1–1023.

**VBIT\_TO\_VSYNC** sets the delay from the detection of V bit changing from 1 to 0 in an EAV sequence, to the asserting edge of VSYNC. Unit of measure is lines. Valid 1–63.

**VWIDTH** sets the width of the VSYNC pulse. Unit of measure is lines. Valid 1–63.

**HSYNC and VSYNC Polarity** bits 0x63[5:4] should be set to the polarity of the source providing the sync signals. Setting these bits does not change the polarity of HSYNC or VSYNC in the encoded TMDS output stream.

### **InfoFrame Data**

The transmitter register map provides simplified direct access to the commonly used AVI InfoFrame registers, and a separate overlay register space for all the other InfoFrame registers.

### **AVI InfoFrame Data**

A dedicated AVI InfoFrame buffer is provided to meet HDMI requirements for transmission every 2 frames. The host fills in the AVI InfoFrame according to the HDMI 1.x specification. This data is used only for transmission, and is not used for any internal register control purposes.

Access. These registers can be read or written individually or by bursts as desired. The data sent out on the link gets updated only when TPI 0x19 is written, either by itself or as the last byte of a burst. Writing TPI 0x19 also causes the values last written to TPI 0x09-0A to be loaded into the chip logic.

 $\rightarrow$  Important Note: After switching to a DVI mode by using TPI 0x0A[1:0], at least the one byte at TPI 0x19 must be written in order for the mode switch to take place.

Certain devices support HDMI 1.4 modes as noted in Appendix D, and require AVI InfoFrame bits to be set appropriately.

Table 15. TPI AVI InfoFrame Data (R/W)

| Table 15. 1F1Av1 infortance Data (N/W) |                                                                  |              |                 |                 |                       |              |       |            |  |  |  |
|----------------------------------------|------------------------------------------------------------------|--------------|-----------------|-----------------|-----------------------|--------------|-------|------------|--|--|--|
| Offset                                 | Bit 7                                                            | Bit 6        | Bit 5           | Bit 4           | Bit 3                 | Bit 2        | Bit 1 | Bit 0      |  |  |  |
| 0x0C                                   |                                                                  |              | 1               | AVI_D           | BYTE0                 |              |       |            |  |  |  |
| [00]                                   |                                                                  |              |                 | AVI InfoFran    | ne Checksum           | X \          | \     |            |  |  |  |
| 0x0D                                   |                                                                  |              |                 | AVI_D           | BYTE1                 |              | 17    |            |  |  |  |
| [00]                                   | Rsvd (0)                                                         | Y            | 1:0             | A0              |                       | 1:0          | S     | 1:0        |  |  |  |
|                                        | 113/4 (0)                                                        |              | Cr Indicator    | Active info     |                       | Data Valid   |       | ormation   |  |  |  |
| 0x0E                                   |                                                                  |              |                 | AVI_D           |                       |              | )     |            |  |  |  |
| [00]                                   | C1:0 M1:0 R3:0                                                   |              |                 |                 |                       |              |       |            |  |  |  |
|                                        | Colorimetry Info Picture Aspect Ratio Active Format Aspect Ratio |              |                 |                 |                       |              |       |            |  |  |  |
| 0x0F                                   | AVI_DBYTE3                                                       |              |                 |                 |                       |              |       |            |  |  |  |
| [00]                                   | ITC EC2:0 Q1:0 SC1:0                                             |              |                 |                 |                       |              |       |            |  |  |  |
|                                        | IT Content                                                       | Ex           | tended Colorime | trv             | -                     | zation Range |       | rm Scaling |  |  |  |
| 0x10                                   |                                                                  |              |                 | AVI D           |                       |              |       |            |  |  |  |
| [00]                                   | Rsvd (0)                                                         |              |                 |                 | VIC6:0                |              |       |            |  |  |  |
|                                        | 113, 4 (0)                                                       |              | <b>~</b>        | Video Fo        | rmat Identificat      | ion Code     |       |            |  |  |  |
| 0x11                                   |                                                                  | l            |                 | AVI_D           |                       |              |       |            |  |  |  |
| [00]                                   | YQ1:0 CN1:0 PR3:0                                                |              |                 |                 |                       |              |       |            |  |  |  |
|                                        | _                                                                | zation Range | Conten          |                 |                       | Pixel Repet  |       |            |  |  |  |
| 0x12                                   |                                                                  |              |                 | EndTo           | pBar                  | •            |       |            |  |  |  |
| [00]                                   |                                                                  |              | Line            | Number of End   | -<br>l of Top Bar – l | LSB          |       |            |  |  |  |
| 0x13                                   |                                                                  |              |                 | MS              |                       |              |       |            |  |  |  |
| [00]                                   |                                                                  |              |                 |                 |                       |              |       |            |  |  |  |
| 0x14                                   |                                                                  |              |                 | StartBo         | ttomBar               |              |       |            |  |  |  |
| [00]                                   |                                                                  |              | Line N          | Number of start | of Bottom Bar -       | - LSB        |       |            |  |  |  |
| 0x15                                   |                                                                  |              |                 | MS              | SB                    |              |       |            |  |  |  |
| [00]                                   |                                                                  |              |                 |                 |                       |              |       |            |  |  |  |
| 0x16                                   |                                                                  |              |                 | EndLe           |                       |              |       |            |  |  |  |
| [00]                                   |                                                                  |              | Pixel           | l Number of En  |                       | LSB          |       |            |  |  |  |
| 0x17                                   |                                                                  |              |                 | MS              | SB                    |              |       |            |  |  |  |
| [00]                                   |                                                                  |              |                 | n 1n '          | l- t- D - ·           |              |       |            |  |  |  |
| <b>0x18</b> [00]                       |                                                                  |              | <b>.</b>        | EndRig          |                       | . an         |       |            |  |  |  |
|                                        |                                                                  |              | Pixel           | Number of End   |                       | LSB          |       |            |  |  |  |
| <b>0x19</b> [00]                       |                                                                  |              |                 | MS              | SB                    |              |       |            |  |  |  |
| [00]                                   |                                                                  |              |                 |                 |                       |              |       |            |  |  |  |

#### Silicon Image, Inc.

**Calculating the Checksum.** The host must calculate the checksum to include the InfoFrame identifier headers and the expected length byte, per the HDMI specification. The routine for generating the checksum is provided below.

#### Other InfoFrame Data

The host writes miscellaneous InfoFrame information as needed to the packet buffers, according to the HDMI 1.x specification. Seven buffers are provided, selected according to TPI 0xBF[2:0]. This data is used only for transmission, and not for any internal control purposes.

Access. These registers can be read individually or by bursts as desired. For writes, they should be accessed as a complete group in a burst. The actual data is transferred to the HDMI transmitter logic only once the final byte of the InfoFrame is written, as determined by the length of the InfoFrame set in 0xBF[2:0]. Alternatively, individual bytes can be modified and then the updated data can be transferred by writing just to the final byte.

| Tab | le 16. TPI Mis | scellanous Inf | oFrame Data | (R/W) |
|-----|----------------|----------------|-------------|-------|
| 6   | Rit 5          | Rit /          | Rit 3       | Rit 2 |

| Offset           | Bit 7                                                                       | Bit 6                                                                                                  | Bit 5         | Bit 4             | Bit 3            | Bit 2           | Bit 1                                                                                                                                             | Bit 0                      |  |
|------------------|-----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|---------------|-------------------|------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|--|
| 0xBF             |                                                                             |                                                                                                        |               | I-F_S             | ELECT            |                 |                                                                                                                                                   |                            |  |
| [00]             | Enable selected InfoFrame transmission 0 – not enabled (default) 1 – enable | Repeat<br>selected<br>InfoFrame<br>transmission<br>0 – don't<br>repeat<br>(default)<br>1 – repeat each | Rs            | vvd O             | Rsvd             | 010 - 01<br>100 | s the InfoFrame<br>ytes except when<br>000 - Reserved<br>01 - SPD or AC<br>Audio (n = 14<br>1 - MPEG or G<br>- Generic 1 / IS<br>- Generic 2 / IS | re noted) CP bytes) BD RC1 |  |
|                  |                                                                             | frame                                                                                                  |               | , · (U)           |                  |                 | 10 – HDMI VSI<br>D (SiI9334/SiI9                                                                                                                  |                            |  |
| 0xC0             |                                                                             |                                                                                                        |               | I-F_              | TYPE             |                 |                                                                                                                                                   |                            |  |
| [00]             | Type InfoFrame Type per CEA-861-E spec  0 – Packet 1 – InfoFrame            |                                                                                                        |               |                   |                  |                 |                                                                                                                                                   |                            |  |
| 0xC1             |                                                                             |                                                                                                        |               | I-F_              | _VER             |                 |                                                                                                                                                   |                            |  |
| [00]             |                                                                             |                                                                                                        | Info          | Frame version p   | er CEA-861-E     | spec            |                                                                                                                                                   |                            |  |
| 0xC2             |                                                                             |                                                                                                        | \(            | I-F_L             | ENGTH            |                 |                                                                                                                                                   |                            |  |
| [00]             | Rsvd = 0                                                                    | Rsvd = 0                                                                                               | Rsvd = 0      |                   | InfoFrame l      | length per CEA- | -861-E spec                                                                                                                                       |                            |  |
| 0xC3             |                                                                             | 80                                                                                                     |               | DBY               | TE0              |                 |                                                                                                                                                   |                            |  |
| [00]             |                                                                             |                                                                                                        |               | InfoFrame         |                  |                 |                                                                                                                                                   |                            |  |
| 0xC4             |                                                                             |                                                                                                        |               | DBY               | TE1              |                 |                                                                                                                                                   |                            |  |
| [00]             |                                                                             | InfoFrame data byte 1                                                                                  |               |                   |                  |                 |                                                                                                                                                   |                            |  |
| 0xC5             |                                                                             |                                                                                                        |               | DBYTE2            | DBYTEn-1         |                 |                                                                                                                                                   |                            |  |
| [00]             |                                                                             | InfoFrame data bytes                                                                                   |               |                   |                  |                 |                                                                                                                                                   |                            |  |
| •                |                                                                             | (0xCD is the last location for Audio InfoFrame)                                                        |               |                   |                  |                 |                                                                                                                                                   |                            |  |
| <b>0xDD</b> [00] |                                                                             |                                                                                                        |               |                   |                  |                 |                                                                                                                                                   |                            |  |
| 0xDE             |                                                                             |                                                                                                        |               | DBY               | TEn              |                 |                                                                                                                                                   |                            |  |
| [00]             |                                                                             |                                                                                                        | Last InfoFran | ne data byte (for | all except Audio | InfoFrames)     |                                                                                                                                                   |                            |  |
|                  | Last InfoFrame data byte (for all except Audio InfoFrames)                  |                                                                                                        |               |                   |                  |                 |                                                                                                                                                   |                            |  |

**Select.** The host chooses the InfoFrame to which the data corresponds, and sets the Enable and Repeat bits, in the I-F\_SELECT byte. When the last byte (n) of that selected InfoFrame group is written, the Enable and Repeat bit settings originally written will take effect. This sequence allows the command, checksum, and data to be written as a continuous burst over the TPI I<sup>2</sup>C interface, preventing a partially written InfoFrame from being sent.

Because there is a limited number of packet buffers, it may be necessary to alternate the buffers where appropriate. For example, ACP packets can be sent every 300ms normally, but interrupted on occasion to use the same buffer to send an SPD packet for identification of the source device.

**Enable bit.** Enables selected InfoFrame for transmission over HDMI. To enable transmission, write "1" into this bit. Once transmission is done, the hardware will reset it back to 0 unless the Repeat bit was also set.

**Repeat bit.** The Repeat bit causes the logic to repeatedly send the selected InfoFrame data each frame. When this bit is set along with Enable (bit [7]), hardware will try to send the InfoFrame once every vertical blanking period. Software has to disable this bit first to force clear of the Enable bit by the hardware.

**Length.** The length is calculated without including the type, version, length, or checksum bytes.

**Calculating the Checksum.** Refer to the previous section for an example of calculating the checksum, noting that the Identifier Code and Length values will change according to the specific InfoFrame being sent.

### Using x.v.Color

All transmitters support sending video data in x.v.Color (xvYCC) format across HDMI. Refer to Appendix D for special color space conversion and GBD handling features of the SiI9136 and SiI9334 transmitters. For all other transmitters, color space conversion is not available; input video data must be provided in the correct x.v.Color format. The programming is the same as the YCbCr 4:4:4 mode of operation.

The Gamut Boundary Descriptor packet is written to the Miscellaneous InfoFrame buffer selected by TPI 0xBF [2:0]=011. This buffer is also designated for use with MPEG packets, but these are rarely required. Contact Silicon Image technical support for recommendations on sending both GBD and MPEG packets in the same system.

### **Extended Colorimetry Standards**

All transmitters support sending video data in  ${\rm sYCC_{601}}$ ,  ${\rm Adobe_{RGB}}$ , and  ${\rm Adobe\,YCC_{601}}$  formats across HDMI. These modes are passed through directly and are not processed by the transmitter. TPI 0x09 and 0x0A must both be set to the same mode (matching input color space and output format) to ensure that these modes are handled properly.

The EC, CN, and YQ bits of the AVI InfoFrame must be set according to the HDMI 1.4 specification when transmitting any of these formats.

### **System Control**

TPI has the ability to determine certain system functional needs and act automatically to control operation. The System Control register configures these functions and also allows the host to override them when needed.

| Offset | Bit 7                     | Bit 6                                               | Bit 5                     | Bit 4                                                   | Bit 3                                                                | Bit 2                                                                                | Bit 1                                                                               | Bit 0                                                                                        |  |
|--------|---------------------------|-----------------------------------------------------|---------------------------|---------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|--|
| 0x1A   | SystemControl             |                                                     |                           |                                                         |                                                                      |                                                                                      |                                                                                     |                                                                                              |  |
| [10]   | Rsvd – write as 0 always. | Link Integrity<br>Mode<br>0 – Static<br>1 – Dynamic | Rsvd – write as 0 always. | TMDS Output Control 0 - Active 1 - Power down (default) | AV Mute 0 – Normal audio/video 1 – Mute HDMI audio/video at receiver | DDC Bus<br>Request by<br>host<br>0 – Host does<br>not need to<br>use DDC<br>1 – Host | DDC Bus Grant by TPI Read: Status 0 – Bus not available 1 – Bus can be used by host | Output Mode<br>Select<br>Write in Hot<br>Plug Service<br>Loop<br>0 – Set DVI<br>1 – Set HDMI |  |
|        |                           |                                                     |                           | QC.                                                     |                                                                      | requests to use DDC                                                                  | Write: Force<br>bus ownership<br>0 – TPI<br>1 – Host                                | 1                                                                                            |  |

Table 17. TPI System Control (R/W)

**DDC Bus Request/Grant.** TPI logic automatically utilizes the DDC bus as needed. If the host needs to use the DDC bus, it must notify TPI logic and then wait until it is safe to take the bus over. The host graphics software should use the DDC bus Request control and Grant status bits as follows.

- 1. Before performing a DDC bus access, the host writes 0x1A[2] = 1 to request the bus.
- 2. It then loops on a read of 0x1A[1] until it returns 1, indicating that it is safe to read the bus. In SiI9334 and SiI9136 this step has to be skipped if HDCP is enabled but video is muted while HDCP is enabled as the bus grant logic waits for Ri reading but the reading does not occur while video is mute. In mentioned above chips this step also can be skipped if HDCP is off.
- 3. Once it has been granted the bus, the host **must** write TPI 0x1A=0x06. This action closes the switch to allow subsequent I<sup>2</sup>C accesses to flow out onto the DDC bus.
- 4. Once the host has finished reading EDID, it must write TPI 0x1A=00 to clear the request. Note that the device will **not** ACK this write.
- 5. Finally, the host must read 0x1A[2:1] and verify that they are 00 (repeat step 4 if not). Reading back from this register opens the switch to direct subsequent I<sup>2</sup>C accesses back to the TPI bus.

If link security has been requested any time since the last hardware reset or hot plug event, HDCP link integrity checking will be taking place every 128 frames. Therefore, in order to receive full access, the host must **disable** link security before requesting use of the DDC bus.

**Output Mode.** During the Hot Plug Service Loop, before register 0x1E is written to 00 to select full-power operational mode, the DVI/HDMI control bit at 0x1A[0] must be written to force the mode of operation.

0 = DVI

1 = HDMI

Register 0x1A can be written and read multiple times while in the Hot Plug Service Loop, but for bit 0, only the last write made is important. After writing 0x1E = 00, the most recent setting of 0x1A[0] is used to establish the operating mode.

The transmitter subsystem will operate in the selected mode (DVI or HDMI) until the next hardware reset, or until the next time 0x1E is written to 0.

**AV Mute.** HDMI allows the display and audio output of the sink device to be muted by remote command. The host can send this command by using the AV Mute bit. This feature is useful when switching video resolutions, for example, to prevent the screen from flickering.

### **Important Notes**

- → 1: Once the system has been set to DVI output mode, the AV mute and un-mute packets can no longer be sent. Therefore, sending an AV Mute packet and then switching from HDMI to DVI output mode could result in a permanently muted screen until the next hardware reset.
- → 2: Setting TPI 0x1A[3] sends an AV Mute command and temporarily disables HDCP encryption, as required for HDMI. However, as there is no concept of an AV Mute command for DVI, setting this bit when in DVI mode results only in disabling HDCP encryption. Therefore, in general, this bit should not be used in DVI mode. Setting this bit on the SiI9136/9334 does not disable HDCP.

**TMDS Output Control.** The transmitter TMDS outputs can be powered down, leaving them floating. TMDS output must be explicitly enabled with this bit after entering operational (D0) mode.

**Link Integrity Mode.** Not used for devices without HDCP. For details, refer to the HDCP section for devices with HDCP capability.

**Resolution Change**. Setting 0x1A[4] = 1 is a signal from the host that a resolution change is about to happen. The host should disable HDCP security using 0x2A[0], wait for at least 64ms or poll 0x29[7:4] to verify that it is disabled, then follow this procedure.

- 1. Disable TMDS Output (0x1A[4] = 1).
- 2. Wait at least 128ms to allow control InfoFrames to pass through to the sink device.
- 3. Change video resolution, and wait for the new resolution to stabilize.
- 4. Set the VMode registers.
- 5. Write the AVI InfoFrame registers (0x0C).
- 6. Enable TMDS Output (0x1A[4] = 0).

Upon completion, re-enable HDCP security if needed using 0x2A[0].

# **Audio Configuration**

The audio subsystem can operate in S/PDIF or I<sup>2</sup>S mode, S/PDIF, I<sup>2</sup>S or DSD mode (DSD only SiI9136/9334), as selected by the host through TPI. In either case, the host determines which configurations are valid by reading the audio descriptors directly from the EDID.

### Configuring Audio using S/PDIF

The S/PDIF audio subsystem selection is made by TPI control. Most operations thereafter are automatic.

#### S/PDIF Initialization and Operation

The transmitter requires only the following initialization for S/PDIF applications.

- 1. Ensure that a valid S/PDIF audio stream is coming into the transmitter.
- 2. Select S/PDIF input mode using register bits 0x26[7:6].

The transmitter supports automatic recognition of new S/PDIF audio rates when the correct header information is supplied in the S/PDIF stream. It continually checks the  $f_s$  value in the S/PDIF stream, and calculates N values accordingly whenever  $f_s$  changes.

For audio sources that do not supply correct S/PDIF stream headers, the information must be programmed manually as described in the Configuring Audio using I2S section.

#### **Additional Audio Features**

The following registers are provided for the host to select an audio mode. The default is Basic Audio, since HDMI hosts are always allowed to send Basic Audio even before reading the EDID descriptors. The Basic Audio configuration can always be selected.

**Audio Muting.** The Mute bit is used when the host has a specific need to temporarily turn off audio. It stops the audio stream to the audio FIFO, muting the audio. However, the audio module is still enabled, so that un-muting requires no additional reinitialization.

Audio Handling. Three modes are available.

- Pass Basic Audio Only. Incoming audio will be transmitted over HDMI only if is uncompressed (PCM) and is 32kHz, 44.1kHz, or 48kHz. All other streams are blocked and the output is muted.
- Pass All Audio Modes. The hardware transmits the audio stream over HDMI exactly as it is received.
- Down-sample Incoming Audio as Needed. The hardware uses the transmitter down-sampler to automatically detect and
  convert incoming high audio rates to their Basic Audio correspondent. For example, 192 kHz audio would always be
  down-sampled to 48 kHz before transmission over HDMI.

Note that for proper operation, the down-sampling feature requires that the incoming S/PDIF header information be correct.

**Audio Override.** By default, the incoming S/PDIF stream header is used by chip logic to automatically configure audio operation. Override bits are provided in registers 0x26 and 0x27 to manually set this information. Note that these bits must be used to set the correct output stream header when the Audio Handling bits in 0x25[1:0] = 10. Setting 0x27[5:3], in particular, will overwrite the incoming audio stream rate data on the outgoing audio packets. Setting the override bits does not affect the Audio InfoFrame information.

Access. These are byte-accessed registers. Refer to the following section for sequence information.

Table 18. TPI Audio Configuration Write Data (RW)

| Offset            | Bit 7           | Bit 6              | Bit 5                        | Bit 4           | Bit 3                      | Bit 2                | Bit 1            | Bit 0          |  |
|-------------------|-----------------|--------------------|------------------------------|-----------------|----------------------------|----------------------|------------------|----------------|--|
| 0x24 <sup>1</sup> |                 |                    | 35:32, Sample Le             |                 | S/PDII                     | F Header bits 27     |                  |                |  |
| [D0]              |                 | refer to IEC609    | 58 specification             |                 |                            | refer to IEC609      | 58 specification |                |  |
| read-only         |                 | T                  | T                            | T               |                            | 1                    |                  |                |  |
| 0x25 <sup>1</sup> | Rsvd            | Rsvd               | Rsvd                         | Rsvd            | Rsvd                       | d Rsvd Audio Han     |                  |                |  |
| [03]              |                 |                    |                              |                 |                            |                      |                  | sic Audio only |  |
|                   |                 |                    |                              |                 |                            |                      |                  | audio modes    |  |
|                   |                 |                    |                              |                 |                            |                      |                  | mple incoming  |  |
|                   |                 |                    |                              |                 |                            |                      |                  | s needed       |  |
|                   |                 |                    |                              |                 |                            |                      |                  | check audio    |  |
|                   |                 |                    |                              |                 |                            |                      |                  | (default)      |  |
| 0x26              |                 | nterface           | Layout Bit                   | Mute            | Audio Co                   | ding Type CT[3:      |                  |                |  |
| [00]              |                 | isabled            | "A" &                        | 0 – Normal      |                            | 0000 – Refer to      |                  | 6              |  |
|                   |                 | S/PDIF             | SiI9136/9334 revisions only: | 1 – Mute        | / )                        | 0001 -               |                  |                |  |
|                   |                 | - I <sup>2</sup> S | audio packet                 |                 |                            | 0010 -               |                  | 1              |  |
|                   |                 | iI9136/9334        | header layout                |                 |                            | 0011 – 1             |                  |                |  |
|                   | 1 X C           | only)              | indicator                    |                 | 0100 – MP3<br>0101 – MPEG2 |                      |                  |                |  |
|                   |                 |                    | 0 – Layout 0                 |                 | (1)                        |                      | - AAC            |                |  |
|                   |                 |                    | (2-channel)                  |                 |                            | 0111 -               |                  |                |  |
|                   |                 |                    | 1 – Layout 1                 |                 | ,                          | 1000 - 1             |                  |                |  |
|                   |                 |                    | (up to 8                     |                 |                            | all others a         | re reserved      |                |  |
|                   |                 |                    | channels)                    |                 |                            |                      |                  |                |  |
| 0x27              | Audio Sample    | e Size SS[1:0]     | Audio Sa                     | ample Frequency | SF[2:0]                    | High Bit-Rate        | Rsvd             | Rsvd           |  |
| [00]              | 00 – Refer to S | Stream Header      | 000 – I                      | Refer to Stream | Header                     | (HBR) Audio          |                  |                |  |
|                   | 01 - 1          | 16-bit             | ) / (                        | 001 – 32kHz     | 16                         | Support <sup>2</sup> |                  |                |  |
|                   |                 | 20-bit             |                              | 010-44.1kHz     |                            | (SiI9136/9334        |                  |                |  |
|                   | 11 - 2          | 24-bit             |                              | 011 – 48kHz     | (/1                        | Tx only)             |                  |                |  |
|                   |                 |                    |                              | 100 – 88.2kHz   |                            | 0 – Disable          |                  |                |  |
|                   |                 |                    | 110 17                       | 101 – 96kHz     | 100.0                      | 1 – Enable           |                  |                |  |
|                   |                 |                    |                              | 6.4kHz (MCLK    |                            | 7                    |                  |                |  |
| 0.00              |                 | <del></del>        | 111 – 15                     | 92kHz (MCLK =   |                            |                      |                  |                |  |
| 0x28              |                 |                    |                              | Rese            | erved                      |                      |                  |                |  |
| [00]              |                 |                    |                              |                 |                            |                      |                  |                |  |

#### Note

- 1. TPI 0x24 and 0x25 are specific to S/PDIF operating mode, and are available only when 0x26[7:6] = 01.
- 2. In previous TPI specifications, TPI 0x27[2:0] were assigned as Audio Channel Count bits [2:0], but were never used. These bits are now reassigned as noted.

**Audio Configuration Overview.** S/PDIF audio handling is fully automated with TPI. The audio logic automatically detects the incoming S/PDIF sampling frequency and makes the register settings to pass the audio through correctly. I<sup>2</sup>S audio handling is nearly as automated; only the sampling frequency needs to be written since it is not available from header information.

The incoming audio data is raw data, which is not parsed in any way by the audio logic. Therefore, information such as audio sample size is not known. Therefore, the data written to 0x26 and 0x27 serves to inform the transmitter of the source choices and preferences.

A typical configuration sequence takes place after a Hot Plug event as follows.

- 1. The host requests and is granted the DDC bus, reads video and audio capabilities from the EDID ROM, and starts sending video at a supported resolution. It also passes sink audio information to the source audio handler.
- 2. The host audio subsystem sends 2-channel uncompressed audio at 48kHz and a 16-bit sample size, the minimum configuration required to be supported by all HDMI sinks. The audio logic passes this audio data through by default. Therefore, audio will be heard immediately at the sink device once the audio input type is selected.

#### Silicon Image, Inc.

- 3. The host audio application makes an appropriate audio mode choice. It writes:
  - register 0x26 with the Mute bit set
  - register 0x27 as required
  - register 0x26 again, this time with the Mute bit cleared and either S/PDIF or I<sup>2</sup>S selected.
- 4. When it detects an unmute write to register 0x26, TPI sends Audio InfoFrames as required by HDMI.

**Pixel Rate.** Slower video pixel rates may not allow enough bandwidth to send compressed modes with high audio sample frequencies and high channel number counts. The only real example of this for CE applications is for 480p resolution, where 8-channel compressed audio is limited to a 48kHz sample frequency.

Therefore, when programming the TPI Audio Configuration registers, the host audio handler may need to eliminate any configurations that are not compatible with the current video mode. Note that high-definition CE modes of 720p, 1080i, and 1080p have pixel rates high enough to leave no restrictions on the audio selection.

The S/PDIF input logic automatically compensates for slow pixel rates with fast S/PDIF stream clocks by increasing the sampling rate.

#### **HDMI Audio InfoFrame Requirements for S/PDIF Operation**

Audio InfoFrame requirements in the HDMI specification are handled automatically for S/PDIF. As long as the S/PDIF stream carries all header information, the HDMI specification allows most Audio InfoFrame information to be set to 0 (the "Refer to Stream Header" selection). The only required information not carried in the stream header is the Speaker Configuration byte of the infoframe, which must always be set according to the CEA-861-E standard when more than two speakers are used. TPI assumes that S/PDIF headers are being provided correctly by the audio host.

# Configuring Audio using I<sup>2</sup>S

The I<sup>2</sup>S audio subsystem selection is made by TPI control.

# I<sup>2</sup>S Initialization and Operation

The transmitter requires the following initialization for I<sup>2</sup>S applications.

- 1. Ensure that a valid I<sup>2</sup>S audio stream is coming into the transmitter.
- 2. Select  $I^2S$  input mode using register bits 0x26[7:6], with Mute enabled (bit [4] = 1).
- 3. Write register 0x20 to select the general incoming SD format.
- 4. Write register 0x1F up to four times, to program each of the SD inputs.
- 5. Program register bits 0x27[5:3] with the correct audio rate.
- 6. Program registers 0x21–25 with the correct header information for the stream that will be sent over HDMI.
- 7. Write registers 0xBF-CD with the appropriate Audio InfoFrame information.
- 8. Set the audio packet header layout indicator to 2-channel or multi-channel mode as needed using the sequence described below. Note that Audio InfoFrame byte 1 must also have this same setting.
- 9. Again write register 0x26 with  $I^2S$  selected, this time with Mute disabled (bit [4] = 0).

I'S Input Configuration Register. Software configures the incoming SD format as shown in Table 19.

| <b>Table 19. 0</b> | Configuration | of I <sup>2</sup> S | Interface ( | (RW) |
|--------------------|---------------|---------------------|-------------|------|
|--------------------|---------------|---------------------|-------------|------|

| Offset | Bit 7                                              | Bit 6                                                     | Bit 5                                                                                      | Bit 4                                      | Bit 3                                                | Bit 2                                            | Bit 1                                            | Bit 0                                        |
|--------|----------------------------------------------------|-----------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------|------------------------------------------------------|--------------------------------------------------|--------------------------------------------------|----------------------------------------------|
| 0x20   |                                                    |                                                           | I                                                                                          | <sup>2</sup> S Input Config                | uration Registe                                      | er                                               |                                                  |                                              |
| [95]   | SCK Sample Edge 0 – Falling (change data on rising | divide the M<br>values accordi<br>MCLK-to- f <sub>s</sub> | olier – the Tx us  ACLK input to p  ing to the 128* p  ratio is for input  ampled output f | for formula. The $f_s$ , not down-         | WS Polarity  - Left when:  0 - WS is  Low  1 - WS is | SD Justify Data is justified: 0 – Left 1 – Right | SD Direction Byte shifted first: 0 – MSB 1 – LSB | WS to SD First Bit Shift? 0 - Yes (per spec) |
|        | edge) 1 – Rising                                   | $000 - 1 \\ 001 - 2 \\ 010 - 3 \\ 011 - 5$                | 128 100<br>56 101<br>84 110                                                                | 0 – 768<br>- – 1024<br>0 – 1152<br>1 – 192 | High                                                 | r Right                                          | 1 ESE                                            | 1 – No                                       |

**I**<sup>2</sup>**S Enable and Mapping.** Software typically writes TPI 0x1F multiple times, with a separate FIFO selected each time, to assign SD pins to FIFOs. A single SD pin may be connected to multiple FIFOs. For example, the same SD0 pin could be assigned to FIFO#1, FIFO#1, FIFO#2, and FIFO#3 in order to provide 8 audio output channels. Unused FIFOs can be assigned to disabled SD inputs.

Note that no gaps are allowed when mapping channels to FIFOs – SD pins must be mapped to FIFO#0 and FIFO#1 before mapping a channel to FIFO#2, and so on.

**Automatic Down-Sample.** This feature provides sample rate conversion of stereo input to the Basic Audio rate that all HDMI sinks are required to accept; the specification allows this level of audio to be sent even before determining the device capabilities from EDID. The logic is only capable of converting a stereo signal, and cannot down-sample more than two channels. The down-sample logic output operates only on FIFO#0.

Table 20. Mapping of I<sup>2</sup>S Interface (RW)

| Offset | Bit 7       | Bit 6 | Bit 5            | Bit 4          | Bit 3           | Bit 2                  | Bit 1         | Bit 0            |
|--------|-------------|-------|------------------|----------------|-----------------|------------------------|---------------|------------------|
| 0x1F   |             |       | $\mathbf{I}^{2}$ | S Enable and M | Iapping Registe | er <sup>i</sup>        |               |                  |
| [00]   | SD pin      | Rsvd  | Select           | Select SD pin  |                 | Swap Left /            | This FIFO wil | l take its input |
|        | selected by | ( 1   | to be connect    | ed to a FIFO   | down-sample     | Right I <sup>2</sup> S | from the SD p | oin selected in  |
|        | [5:4]       |       | 00 –             | SD0            | to Basic        | channels on            | bits [5:4]    |                  |
|        | 0 – Disable |       | 01 –             | SD1            | Audio mode      | this channel           | 00 - F        | IFO#0            |
|        | 1 – Enable  |       | 10 –             | SD2            | (FIFO#0         | 0 – No swap            | 01 - F        | IFO#1            |
|        |             |       | 11 -             | SD3            | only)           | 1 - Swap               | 10 – FIFO#2   |                  |
|        |             |       |                  |                | 0 – Disable     |                        | 11 – F        | IFO#3            |
|        |             |       |                  |                | 1 – Enable      |                        |               |                  |

#### Notes

 Reads of this register return the last value written, so the readback value has meaning only for the channel most recently configured.

#### **Header Layout Setting Sequence**

Use TPI 0x26[5] to select the header layout. Once set, this bit setting will remain in effect and does not need to be rewritten on  $f_s$  change events.

 $\rightarrow$  Exception. For the SiI9022 and SiI9024 (non "A") transmitters and the SiI9222/9226 transmitter, TPI 0x26[5] is not available. Instead, follow the sequence below:

The sequence must be repeated any time audio has been muted before it is unmuted, or if the  $f_s$  rate has changed, because hardware will overwrite the previously programmed information on either of those events.

Table 21. Audio Packet Header Layout Indicator (R/W)

|              | Bit 7 | Bit 6 | Bit 5     | Bit 4        | Bit 3 | Bit 2 | Bit 1         | Bit 0        |
|--------------|-------|-------|-----------|--------------|-------|-------|---------------|--------------|
| Internal     |       |       | Rsvd – wr | ite as read. |       |       | Layout        | Rsvd - write |
| Register     |       |       |           |              |       |       | Audio packet  | as read.     |
| available at |       |       |           |              |       |       | header layout |              |
| 0xBE when:   |       |       |           |              |       |       | indicator     |              |
| 0xBC=02      |       |       |           |              |       |       | 0 – Layout 0  |              |
| 0xBD=2F      |       |       |           |              |       |       | (2-channel)   |              |
|              |       |       |           |              |       |       | 1 – Layout 1  |              |
|              |       |       |           |              |       |       | (up to 8      |              |
|              |       |       |           |              |       |       | channels)     |              |

### **Audio Word Length**

When using the  $I^2S$  interface, audio word length must be defined independently for the incoming  $I^2S$  stream and outgoing HDMI stream.

**Output Word Length.** Whether for S/PDIF or  $I^2S$ , the HDMI stream always accommodates a 24-bit audio sample word, regardless of whether all bits of the word are used. An indicator is provided in the stream header to identify the actual length of data to be used. For S/PDIF, this information is transferred automatically to HDMI. However, for  $I^2S$ , it is necessary to program the length explicitly if it is less than the default value of 24.

Use TPI 0x25[3:0] to select the word length to be indicated to the receiver as shown in Table 22.

Table 22. Stream Header Settings for I<sup>2</sup>S (RW)

Note that these registers are available **only** when TPI 0x26[7:6] = 10 to select  $I^2S$  input.

| Offset | Bit 7                                                 | Bit 6                         | Bit 5                    | Bit 4                    | Bit 3                        | Bit 2                      | Bit 1              | Bit 0 |  |  |  |
|--------|-------------------------------------------------------|-------------------------------|--------------------------|--------------------------|------------------------------|----------------------------|--------------------|-------|--|--|--|
| 0x21   |                                                       |                               | 8                        | I <sup>2</sup> S Channel | Status Byte 0                |                            |                    | •     |  |  |  |
| [00]   | cbit7                                                 | cbit6                         | cbit5                    | cbit4                    | cbit3                        | cbit2                      | cbit1              | cbit0 |  |  |  |
| 0x22   |                                                       |                               | I <sup>2</sup> S Ch      | nannel Status 1          | Byte 1: Catego               | ry Code                    |                    |       |  |  |  |
| [00]   | cbit15 cbit14 cbit13 cbit12 cbit11 cbit10 cbit9 cbit8 |                               |                          |                          |                              |                            |                    |       |  |  |  |
| 0x23   |                                                       |                               | I <sup>2</sup> S Channe  | l Status Byte 2          | : Source, Cha                | nnel Number                |                    |       |  |  |  |
| [00]   |                                                       | I <sup>2</sup> S Channel N    | umber cbit23:20          |                          |                              | I <sup>2</sup> S Source Nu | mber cbit19:16     |       |  |  |  |
| 0x24   |                                                       |                               | I <sup>2</sup> S Chanı   | nel Status Byte          | 3: Accuracy,                 | Sampling $f_{\rm s}$       |                    |       |  |  |  |
| [0F]   |                                                       | Clock Accu                    | racy cbit31:28           |                          |                              | Sampling Frequency         | uency cbit27:24    |       |  |  |  |
|        |                                                       |                               |                          |                          | ,                            | 0000 - 4                   | 44.1kHz            |       |  |  |  |
|        |                                                       |                               |                          |                          |                              |                            | 88.2kHz            |       |  |  |  |
|        |                                                       | •                             |                          |                          |                              |                            | 76.4kHz            |       |  |  |  |
|        |                                                       |                               |                          |                          | 0010 – 48kHz<br>1010 – 96kHz |                            |                    |       |  |  |  |
|        |                                                       |                               | 10                       |                          |                              |                            | 96KHZ<br>192kHz    |       |  |  |  |
|        |                                                       |                               | × V                      | ,                        |                              |                            | 32kHz              |       |  |  |  |
|        |                                                       | C()                           |                          |                          |                              |                            | kHz (HBRA)         |       |  |  |  |
|        |                                                       | $X \cup X$                    |                          |                          |                              |                            | t indicated        |       |  |  |  |
| 0x25   |                                                       |                               | I <sup>2</sup> S Channel | Status Byte 4            | Original $f_s$ , S           | ample Length               |                    |       |  |  |  |
| [0B]   | Or                                                    | iginal f <sub>s</sub> , Chanr | nel Status bits 39:      | 36                       | Sar                          | nple Length, Chai          | nnel Status bits   | 35:32 |  |  |  |
|        |                                                       | Refer to IEC60                | 958 specification        | l                        |                              | Word                       | Length             |       |  |  |  |
|        |                                                       |                               |                          |                          |                              | 1011 – 24 b                | oits (default)     |       |  |  |  |
|        |                                                       |                               |                          |                          | 1001 – 23 bits               |                            |                    |       |  |  |  |
|        |                                                       |                               |                          |                          | 0101 – 22 bits               |                            |                    |       |  |  |  |
|        |                                                       |                               |                          |                          | 1101 – 21 bits               |                            |                    |       |  |  |  |
|        |                                                       |                               |                          |                          | 1010 - 20  bits              |                            |                    |       |  |  |  |
|        |                                                       |                               |                          |                          |                              |                            | 19 bits            |       |  |  |  |
|        |                                                       |                               |                          |                          |                              |                            | 18 bits            |       |  |  |  |
|        |                                                       |                               |                          |                          |                              |                            | 17 bits<br>16 bits |       |  |  |  |

**Input Word Length.** Unlike S/PDIF, the incoming I<sup>2</sup>S audio stream has a variable word length. The output word length should be set to this same value or less, but never more.

The I<sup>2</sup>S sampling circuit defaults to 24-bit word length. The Input Word Length bits follow the same definition as the output word length bits: they are automatically set whenever the Output Word Length (TPI 0x25[3:0]) is written. To configure the circuit for sample word sizes less then 24 bits, follow the procedure listed below; it is necessary only if the Input and Output word length values are different.

→ Exception. This setting procedure is mandatory for the SiI9022 and SiI9024 (non "A") devices.

Table 23. Word Length Selection (R/W)

|           | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3    | Bit 2       | Bit 1          | Bit 0 |
|-----------|-------|-------|-------|-------|----------|-------------|----------------|-------|
| Internal  |       |       |       |       |          | Word        | Length         |       |
| Register  |       |       |       |       |          | 1011 – 24 b | its (default); |       |
| available |       |       |       | -1/7  |          |             | 23 bits;       |       |
| at 0xBE   |       |       |       |       |          | 0101 -      | 22 bits;       |       |
| when:     |       |       |       | /     |          | 1101 –      | 21 bits;       |       |
| 0xBC=02   |       |       |       |       | $\smile$ | 1010 -      | 20 bits        |       |
| 0xBD=24   |       |       |       |       |          | 1000 -      | 19 bits        |       |
|           |       |       |       |       |          | 0100 -      | 18 bits        |       |
|           |       |       | ( ) ( |       |          |             | 17 bits        |       |
|           |       |       |       |       |          | 0010 -      | 16 bits        |       |

## HDMI Audio InfoFrame Requirements for I2S Operation

Audio InfoFrame requirements in the HDMI specification must be handled manually for  $I^2S$ . All stream header information must be programmed by the host. The host must also program the Audio InfoFrame information.

HDMI allows for up to eight channels of audio content. Two channels pass through each of the four FIFOs. HDMI does not restrict the source to use any specific subset of the FIFOs. For example, 4-channel content can use many combinations of two FIFOs and two fields in the Audio InfoFrame packets (indicated by each packet's B.X and SP.X bits; see the *HDMI Specification*) limited only by the channel assignment choices in EIA/CEA-861-E Annex K.

The HDMI transmitter logic sets the B and PR bits automatically in each Audio InfoFrame packet, using both the I<sup>2</sup>S channel enables and the channel FIFO mapping. Some HDMI receiver chips do not make the arriving B and PR bit information accessible to the sink firmware. Therefore, the only indicator of *used audio channels* is in Data Byte 4 of the Audio InfoFrame packet.

 $\rightarrow$  Note: Since the transmitter can be connected to a sink or repeater with SPDIF output, it is sometimes needed to control IEC60958 Vality bit (V bit). It can be done as follows.

### **Configuring Audio for DSD Format**

The Direct Stream Digital (DSD) Audio format, referred to as One-Bit Audio format in the HDMI specification, is supported using the I<sup>2</sup>S clock and data inputs, S/PDIF input, and two additional pins for the 7<sup>th</sup> and 8<sup>th</sup> channels. Not all transmitters support DSD – for details, refer to the device data sheet.

Setting TPI 0x26[7:6]=11 selects the DSD input format. When selected, the appropriate I<sup>2</sup>S configuration register bits become control for the DSD logic. According to the number of channels, register 0x1F needs to be set up the same way as for I<sup>2</sup>S input. Note that automatic down sampling of One-Bit Audio is not possible. Therefore, TPI 0x1F[3] needs to be set to

The following is an example of how to set up DSD Audio for 5.1 Channel SACD transfer.

```
a) Write 0x26=0xF0 // DSD, Layout 1, Mute
b) Write 0x1F=0x80
```

- c) Write 0x1F=0x91
- d) Write 0x1F=0xA2

In addition to these settings, for standard 5.1-channel SACD, the following Audio InfoFrame fields need to be set:

- Coding Type (CT)  $\rightarrow$  0x00 (Refer to Stream Header)
- Channel Count (CC)  $\rightarrow$  0x05 (6 Channels)
- Sample Frequency (SF)  $\rightarrow$  0x02 (44.1kHz).

Other settings are also possible depending on usage case.

As a final step, un-mute the audio inputs.

```
e) Write 0x26=0xE0 // DSD, Layout 1
```

### **Configuring Audio for HBR Format**

High Bit Rate (HBR) Audio is always transferred via I<sup>2</sup>S using all 4 data lines (SD0-SD3). The following is an example of how to set up HBR Audio.

```
a) Write 0x26=0x90 // I2S, Layout 0, b) Write 0x27=0xFC // HBR Audio, 192
                                          192kHz,
                                                     24 bit
c) Write 0x1F=0x80
d) Write 0x1F=0x91
e) Write 0x1F=0xA2
f) Write 0x1F=0xB3
g) Write 0x26=0x80 //
                            I2S,
                                   Layout 0,
```

Note that the Sample Frequency field (SF) of the Audio InfoFrame needs to be set to the correct value (for this example, to 192kHz) as channel status data is not sent across HDMI when HBR Audio is enabled.

→ Important Note: For HBR audio, the HDMI specification requires the Layout bit TPI 0x26[5] to be cleared to 0.

→ Important Note: For the SiI 9136 / 9334 I2S IN Ctrl must be set through the indexed register 0x1D.

```
// Set I2S IN CTRL
   1) Write 0xBC=0x01
                                           // Internal page 1
  2) Write 0xBD=0x1D
                                           // Indexed register 1D
  3) Read 0xBE
                                          // Read current value
                                    // Change only the identified bits
  4) Modify bit[5] = 1
   5) Write 0xBE
                                           // Write back modified value
```

# **Interrupt Service**

TPI can be configured to generate an interrupt to the host to notify it of various events. The host can either poll for activity or use an interrupt handler routine. TPI generates only a single interrupt signal (INT) to the host.

# **Interrupt Enable Register**

Enables TPI and transmitter to generate interrupts to the host. Hot plug interrupts to the host will be generated even in D3 (low-power) state. Writing any bit to 1 enables the interrupt source, and also clears any pending interrupts. Note that writing 0 to disable the interrupt does not clear any previously pending interrupt.

Access. This register is accessed as a single byte.

Table 24. TPI Interrupt Enable (R/W)

| Offset | Bit 7          | Bit 6       | Bit 5       | Bit 4       | Bit 3          | Bit 2                    | Bit 1       | Bit 0       |
|--------|----------------|-------------|-------------|-------------|----------------|--------------------------|-------------|-------------|
| 0x3C   | HDCP           | HDCP V*     | Security    | Audio Error | CPI            | CTRL Bus                 | Receiver    | Hot Plug /  |
| [00]   | Authentication | Value ready | Status      | Event       | Event in place | Event in place           | Sense Event | Connection  |
|        | Status Change  | 0 – Disable | Change      | 0 – Disable | of Rx Sense    | of Hot Plug <sup>1</sup> | 0 – Disable | (cable      |
|        | 0 – Disable    | 1 – Enable  | 0 - Disable | 1 – Enable  | 0 – Disable    | 0 – Disable              | 1 – Enable  | plugged/    |
|        | 1 – Enable     |             | 1 – Enable  |             | 1 – Enable     | 1 – Enable               |             | unplugged)  |
|        |                |             |             | \ ` X       |                |                          |             | Event       |
|        |                |             |             |             | $\smile$       |                          |             | 0 – Disable |
|        |                |             |             |             |                | X                        |             | 1 – Enable  |

Note

1. Applicable to SiI923x Mobile HD Link devices only

# **Interrupt Status Register**

Shows current status of interrupt events, even if the event has been disabled. This register can be polled for activity if the associated interrupt has been disabled. Write 1 to interrupt bits to clear the 'pending' status. Bits 3 and 2 (bits 3:0 on Mobile HD Link devices) serve only to show the current state and cannot be cleared.

Access. This register is accessed as a single byte.

Table 25. TPI Interrupt Status (R/W)

| Offset | Bit 7          | Bit 6       | Bit 5    | Bit 4       | Bit 3            | Bit 2            | Bit 1           | Bit 0         |
|--------|----------------|-------------|----------|-------------|------------------|------------------|-----------------|---------------|
| 0x3D   | HDCP           | HDCP V*     | Security | Audio Error | RxSense          | Hot Plug pin     | Receiver        | Hot Plug /    |
| [00]   | Authentication | Value ready | Status   | Event       | current state or | current state or | Sense Event     | Connection    |
|        | status change  | Event       | Change   | pending     | CPI Event        | CTRL Bus         | pending or      | Event pending |
|        | Event pending  | pending     | Event    | 0 – No      | pending state    | Transaction      | CTRL Bus        | 0 - No        |
|        | 0 – No         | 0 – No      | pending  | 1 – Yes     | (RO)             |                  | Error indicated | 1 – Yes       |
|        | 1 – Yes        | 1 – Yes     | 0 – No   | 71          | 0 – No Rx        | state (RO)       | 0 – No          |               |
|        |                |             | 1 – Yes  |             | sensed/CPI       | 0 – HP Low or    | 1 – Yes         |               |
|        |                |             |          |             | 1 – Powered      | no event         |                 |               |
|        |                | X           |          |             | Rx attached/     | pending          |                 |               |
|        |                |             |          |             | CPI event        | 1 – HP High      |                 |               |
|        |                |             |          |             | pending          | or CTRL event    |                 |               |
|        |                |             |          |             |                  | pending          |                 |               |
| 0x3E   |                | •           | Rese     | erved       |                  |                  | Received 1st    | HDMI Link     |
| [00]   |                |             |          |             |                  |                  | byte of KSV     | Stable        |
|        |                |             |          |             |                  |                  | 0 – No          | 0 – No        |
|        |                |             |          |             |                  |                  | 1 – Yes         | 1 – Yes       |
| 0x3F   |                |             | Rese     | erved       |                  |                  | Interrupt       | Interrupt     |
| [00]   |                |             |          |             |                  |                  | Control         | Control HDMI  |
|        |                |             |          |             |                  |                  | Received 1st    | Link Stable   |
|        |                |             |          |             |                  |                  | Byte of KSV     | 0 – Disable   |
|        |                |             |          |             |                  |                  | 0 – Disable     | 1 – Enable    |
|        |                |             |          |             |                  |                  | 1- Enable       |               |

#### Silicon Image, Inc.

**Hot Plug / Connection.** The Hot Plug *state* (HTPLG signal from the DVI or HDMI sink) indicates whether a display is attached (the EDID is readable, but the display is not necessarily powered up). The Hot Plug *event* indicates whether the state has changed. For Mobile HD Link devices, this event and state are "virtual" and reflect the combined status of both the remote HTPLG pin at the HDMI connector of the bridge device and the connection state of the CTRL bus.

**Receiver Sense.** The Receiver Sense *state* (RxSense signal from HDCP) indicates whether a powered-up receiver is sensed (whether the TMDS lines are being pulled externally to 3.3V). The Receiver Sense *event* indicates whether the state has changed. Note that to clear the Receiver Sense event bit on Mobile HD Link devices, the host may need to use the CTRL bus register set, as noted in Appendix B.

**CPI Event.** Even though the CPI register set is accessed at a completely separate  $I^2C$  slave address, CPI event pending status can optionally be reflected in the TPI Interrupt Status register in place of the Receiver Sense status bit. In this way, a single register read is adequate to check all interrupt sources at once. Setting 0x3C[3] = 1 allows 0x3D[3] to indicate a CPI Event Pending status. Note that the event itself must be cleared from the CPI registers (writing 1 to 0x3D[3] has no effect).

To further clarify: Setting 0x3C[3]=1 simply allows the CPI interrupt pending status registers to reflect into 0x3D[3]. The interrupt is caused by enabling its source in the CPI registers, not by setting 0x3C[3]=1 – the interrupt would happen just the same if this bit were 0. It is only a convenient way to be able to see the pending CPI interrupt status from the main TPI interrupt register.

**CTRL Transaction Event.** The CTRL bus transaction registers are used to control and monitor Private Channel exchanges for Mobile HD Link devices, as described in the *Link Control Bus Programmer's Reference* (SiI-PR-1031). Even though this register set is accessed in a separate address block, CTRL bus transaction event pending status can optionally be reflected in the TPI Interrupt Status register in place of the Hot Plug status bit. In this way, a single register read is adequate to check all interrupt sources at once. Setting 0x3C[2] = 1 allows 0x3D[2] to indicate CTRL bus transaction event pending status. Note that the event itself must be cleared from the CTRL bus registers (writing 1 to 0x3D[2] has no effect).

**CTRL Bus Error Event.** As noted above, the CTRL bus register set is accessed in a separate address block; that set includes the interrupt status registers associated with CTRL bus errors. CTRL bus error event pending status can optionally be reflected in the TPI Interrupt Status register at 0x3D[1]. Whether this bit represents RxSense events, CTRL bus error events, or both, is determined by a bit setting in the CTRL bus register set.

**Audio Error.** The Audio Error event indicates that an event related to the incoming S/PDIF audio stream has been detected and handled automatically. The most common event is a change in audio header  $f_s$  information. The hardware handles the event without a need for intervention, but the host can use this interrupt to read back the updated status information. No audio events related to  $I^2S$  input are reported.

**Security Status Change.** Any change in the Link Status value (TPI 0x29[5:4]) generates a Security Status Change event so that the host can take appropriate action to re-establish the link.

**HDCP V\* Value Ready.** Once a V\* value is selected, this event indicates that the computation has completed and the value is available (TPI 0x31[3] = 1).

Note: This interrupt feature is functional only on the SiI9136/9334 Tx and SiI923x Tx devices.

**HDCP Authentication Status Change.** An authentication status change event reflects changes in TPI 0x29[7:6], indicating that:

- The previous authentication request (from a write to the Protection Level bit) has completed successfully.
- The extended authentication process failed to complete within ~5s.
- An Ri mismatch has caused authentication to fail.

Refer to the "Extended Link Protection Level" discussion in the HDCP section for details.

# **Interrupt Operation**

The chip provides an interrupt signal INT that is programmable with either active-high (driven) or active-low (open drain) polarity when in SiI9020 Tx Compatible Mode (refer to Appendix A). However, in TPI register mode, this line is pre-set to operate as active low, which allows the external signal to be shared with other active-low interrupt-capable devices.

A number of interrupt functions can be optionally added to INT after startup. If the host enables interrupt sources by setting bits in register 0x3C, one or more events from an enabled source cause a pulse on the INT line. The host will use the signal to recognize and service the interrupt. This sequence is illustrated in Figure 6.



Figure 6. INT Pulse on Event other than HTPLG

When the host clears the interrupt event (by writing 1 to the triggering Interrupt Status Register bit), the INT line will go high, as long as there are no more active events.  $T_{INT\_ACTIVE}$  duration depends on the response time of the host and firmware.

Before leaving the service routine, the host should poll for additional events that could have occurred after the host completed the initial service.

For SiI9334 and SiI9136: To use the interrupt pin in D2 or D3 power states, it is required to make a software reset (setting and then clearing 0x40[1]) before entering the power down modes.

For SiI 9022A and 9024A: To use the interrupt in D3 power state, it is required to make hardware reset before entering the power down mode and HPD must be low or Cable must not be connected prior to entering D3 Hot or D3 Cold mode for wake-up to be valid.

# **TPI System Reset And Control**

The transmitter subsystem has additional control necessary from the firmware

Table 26. TPI Soft Reset (R/W)

| Offset | Bit 7                                                 | Bit 6                                     | Bit 5 | Bit 4         | Bit 3          | Bit 2                                                 | Bit 1    | Bit 0                                          |
|--------|-------------------------------------------------------|-------------------------------------------|-------|---------------|----------------|-------------------------------------------------------|----------|------------------------------------------------|
| 0x40   |                                                       |                                           |       | TPI Soft Rese | et and Control |                                                       |          |                                                |
| [00]   | Alternative TMDS Clock Stable 0 = Unstable 1 = Stable | TMDS Clock Stable 0 = Unstable 1 = Stable |       | Reserved      |                | Deep Color<br>GCP Packet<br>0 = Disable<br>1 = Enable | Reserved | Software<br>Reset<br>0 = Disable<br>1 = Enable |

**Software Reset** – Reset all sections, including the audio FIFO, except registers that are user configurable. Caution: CEC operation is not guaranteed after a Software Reset because the software rewset clears only write pointer while keeping the read pointer. Therefore, there will be mismatches in write/read pointers, the amount of mismatch will depend on when software reset is issued.

Deep Color GCP Packet - Enable the General Control Packet transmission for Deep Color operation.

TMDS Clock Stable – IDCK to TMDS clock is stable and the Transmitter can send reliable data on the TMDS link. A change to the IDCK sets this bit LOW. Along with a status bit for TMDS Clock Stable there is a TPI Interrupt (TPI 0x3E[0]) for TMDS Clock Stable and a corresponding Interrupt Enable (TPI 0x3F[0]).

Alternative TMDS Clock Stable – Similar to TMDS Clock Stable, but uses alternative method for clock checking. There is no interrupt associated with this bit change.

# **Power State Control and Hot Plug Management**

The transmitter subsystem requires control of power state after a hardware reset, following by ongoing management of plug events to determine when the subsystem should be put back into a low-power mode. Note that the SiI9136/9334 Tx defaults to device power state D0 after reset, while all other devices come up in D2 state.

# **Transmitter Power State Register**

TPI supports ACPI power states D0, D2, and D3. Transition from D0 to any other state requires only a write to the Power\_state[1:0] bits.

When the host writes 0x1E[1:0] after reset, the subsystem operates as follows.

#### $\rightarrow$ 03 (D3):

- An RSEN or Hot Plug interrupt event bit in TPI 0x3D[1:0] must be set **prior** to entry to D3 if a wakeup interrupt is to be enabled.
  - → Exception: For the SiI9136/9334 Tx only, if a wakeup interrupt will be enabled, it is also necessary to first reset internal logic before entering D3 state. Otherwise, INT will be asserted immediately if HPD is high on entry to D3.

```
1. Set TPI 0x40[0] = 1 // Assert software reset 2. Clear TPI 0x40[0] = 0 // Clear software reset
```

#### → Exception: For the SiI9022A/9024A Tx:

- 1. A full hardware reset is required to wake the system up from D3 Hot or D3 Cold mode.
- HPD must be low or Cable must not be connected prior to entering D3 Cold but is optional per usage model on D3 Hot mode for wake-up to be valid.

### For D3 Cold:

- 1. Disconnect Cable
- 2. Clear any pending interrupts via TPI 0x3D
- 3. Reset SiI9022A/9024A Tx via HW
- 4. Write device address 0x72, register offset 0xC7 = 0x00 to enter TPI mode
- 5. Set INT# source to Hotplug via TPI 0x3C[0] = 1b
- 6. Clear any pending interrupts via TPI 0x3D
- 7. Enter D3 Cold mode via TPI 0x1E[1:0] = 11b

#### For D3 Hot

- 1. Cable can be disconnected or left connected.
- 2. Set INT# source to either RSEN or HPD
- 3. Clear any pending interrupts via TPI 0x3D
- 4. Enable D3 Hot mode via register 0x1E[1:0] = 11b
- 5. Go back to D3 Hot or enter D3 Cold if cable is unconnected or wake up if cable is connected based on cable setting before entering D3 Hot.

| RSEN   | Hot Plug |
|--------|----------|
| D3 Hot | D3 Hot   |
|        | D3 Cold  |

- The transmitter is brought to its lowest-power state.
- The host can no longer read any registers.
- If a wakeup interrupt bit was set before entering D3 state, a plug-in event will cause INT to be asserted and stay there (it cannot be cleared since register access is disabled).
- The host must assert RESET# to the chip to leave D3 state. Reset is **required** for proper return from D3.

#### Silicon Image, Inc.

#### → 02 (D2):

- The transmitter is brought to a low-power state, but not quite as low as D3 state.
- Host can read registers.
- A plug-in event will cause INT to be asserted if enabled.
  - → Exception: For the SiI9136/9334 Tx only it is **also** necessary to first reset internal logic before entering D2 state

```
1. Set TPI 0x40[0] = 1 // Assert software reset 2. Clear TPI 0x40[0] = 0 // Clear software reset
```

- The host must then program the system back to D0 state in order to restore full operation, and must clear the host plug interrupt in TPI 0x3D to allow INT to be deasserted.

#### → 00 (D0):

- The transmitter is brought to full operation. TMDS output will be enabled (disabled for SiI9136/9334) according to TPI 0x1A settings.
- Writing D1 has the same effect as writing D0.

### D0→D2 Transition

- The D2 state powers down the transmitter (TMDS output is disabled), but leaves the registers operational. All register settings remain unchanged.

#### D2→D0 Transition

- All register settings remain unchanged except for 0x1A, which disables TMDS output.

### **Hot vs Cold Wakeup Modes**

The SiI9022A/SiI9024A and SiI9136/9334 devices offer a deeper power saving mode than other devices. Enabling best power savings requires disabling one of the wakeup features.

- Hot Plug Detect (HDP from the HDMI connector) is always available as a wakeup source in D2 and D3 states.
- Receiver Sense (RSEN, monitoring the TMDS lines for active pullups at the receiver side) is only available as a wakeup source when TPI 0x1E[2]=0.

**SiI9022A/SiI9024A Tx.** TPI 0x1E[2] is effective only for D3 state. It defaults to a setting of 0, for which the D3 description above is valid, except that the power consumption is not yet at its absolute lowest. This is known as D3hot mode, in which HPD and RSEN wakeup events can be monitored.

To enter the lowest power mode, the host must write TPI 0x1E[2]=1 to select D3cold mode *prior* to writing TPI 0x1E[1:0]=11. That is, the mode must already be set before selecting D3 mode. In D3cold state, the chip will go to its absolute lowest power state. However, it will ignore HPD and RSEN wakeup events regardless of other programming.

**SiI9136/9334 Tx.** TPI 0x1E[2] is effective for both D3 and D2 states. It defaults to a setting of 0, for which the D3 description above is valid, except that the power consumption is not yet at its absolute lowest. This is known as D3hot mode, in which HPD and RSEN wakeup events can be monitored.

**Other Devices.** Other devices do not implement this bit, and go to a D3hot state within D3 state – that is, they are always able to generate an interrupt within D3 state (if the interrupt was enabled prior to entry to D3 state).

Access. This register is accessed as a single byte.

**Table 27. TPI Device Power State Control Data (R/W)** 

| Off              | set | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2                                      | Bit 1                 | Bit 0                 |
|------------------|-----|-------|-------|-------|-------|-------|--------------------------------------------|-----------------------|-----------------------|
| <b>0</b> x<br>[0 |     |       |       | Rsvd  | 40,   | 0,0   | Wakeup state <sup>1</sup> 0 – Hot 1 – Cold | Tx Power_<br>state[1] | Tx Power_<br>state[0] |

### **Hot Plug Management**

To properly handle plug and unplug events, the host must implement the Hot Plug Service Loop.

#### **Hot Plug Service Loop**

After the host releases Reset to the HDMI transmitter subsystem and initializes the part, the host program typically enters a Hot Plug Service Loop. The transmitter subsystem logic monitors for Hot Plug activity, but will not attempt detection of the attached device until the host program takes specific action.

During this time, the following registers are of importance.

- Request/Grant register 0x1A. Any time the host wants to read EDID, it must follow the correct procedure for requesting access to the DDC bus.
- Interrupt Enable 0x3C. If desired, interrupt-driven operation can be enabled through TPI 0x3C. Otherwise polling is used. The bits in 0x3C serve only to enable corresponding active interrupt event bits in 0x3D to cause the INT line to go low.
- Interrupt Status 0x3D. Whether polling or interrupt driven mode is used, the host uses TPI 0x3D to monitor and service all hot plug activity.

The host can poll the Interrupt Status register to watch for EDID availability (bit 2 = 1) and monitor powered-on status (bit 3 = 1), or can enable interrupts for hot plug events.

**Suggested Service Flow.** When the host either receives an interrupt or polls TPI 0x3D and detects Hot Plug activity with TPI 0x3D[0] = 1, it should follow this procedure.

- 1. Clear the service event. Write TPI 0x3D[1:0] = 11 to clear the event.
- 2. Read and record the active pin states. TPI 0x3D[3:2] provide active state information for the HPD and RSEN signal levels.
- 3. Determine the event that occurred.
  - If the prior state was "plugged-in", an Unplug event has occurred. An interrupt is registered **immediately** in TPI 0x3D[1:0] for an Unplug event. TPI 0x3D[3:2] = 00 confirms an Unplug event; any other state indicates instability in the connection (which should be monitored until it becomes stable before proceeding).
  - If TPI 0x3D[2] = 1, a Plug event has occurred and has likely stabilized. Interrupts due to Plug events are **delayed** until after the HPD signal has stabilized at a High level for ~500ms. Host software can choose to provide additional de-bouncing if desired (See Hot Plug Delay De-bounce).
- 4. Take action as needed.
  - For a confirmed Plug event, the host should use the Request / Grant protocol to take control of the DDC bus and read EDID as described in the Detailed Sequences section.
  - For an Unplug event, the host should stop sending all video. This step also ensures that no secure video content is being sent.

#### **Operating Sequences**

Some of the major events involved in setting up and running the chip are illustrated below.

**Reset.** The host is required to reset the transmitter subsystem at power-up time. The reset pulse width  $T_{RST}$  should meet the minimum requirement of each device. Please refer to the respective Transmitter Data Sheet of the device used to determine the minimum value. **DDC Access by HDCP Subsystem.** When the host selects Operational (D0) state, the chip reserves the DDC bus for immediate host use. As always, the host must use the request/grant mechanism to get the bus. However, only after it has finished and releases the request will the HDCP subsystem look for an HDCP-capable sink on the DDC bus.

In all future uses of the bus, the host must rely on the Request/Grant register bits to use the DDC bus, preventing conflicts with the HDCP logic.



Figure 7. Hot Plug Control Output Timing

| Parameter        | Description                                          | min | max | unit |
|------------------|------------------------------------------------------|-----|-----|------|
| $T_{RST}$        | Reset pulse width                                    | 50  |     | us   |
| T <sub>ACC</sub> | Time from reset until host can access chip registers | _   | 1   | ms   |

**Hot Unplug and Plug-in.** When the sink device is unplugged, or if the sink device momentarily toggles its HTPLG line low, the hardware immediately returns a Link Lost message when queried by way of TPI. If the interrupt is enabled, the INT line is also asserted until the host clears the interrupt.

The host should check register 0x3D[2] to determine whether a hot plug or hot unplug event is being signaled. If hot plug, the host should continue checking for a minimum of  $T_{RST\_DLY}$  before recognizing the attachment state, to ensure that the HDMI plug attachment is stable.



**Figure 8. Hot Plug Control Output Timing** 

| Parameter               | Description                                             | min | typ | max | unit |
|-------------------------|---------------------------------------------------------|-----|-----|-----|------|
| $T_{PLUG\_DLY}$         | Delay from Hot Plug (HPD) HIGH and stable to INT active | 400 | 480 | 600 | ms   |
|                         | (programmable, see Hot Plug Delay De-bounce)            | 7.  |     |     |      |
| T <sub>UNPLUG DLY</sub> | Delay from Hot Plug (HPD) LOW to INT active             |     | _   | 1   | ms   |
| _                       | (not programmable)                                      |     |     |     |      |

### **Hot Plug Delay De-bounce:**

The hot plug delay debounce is programmable in steps of 3.4ms. The logic needs to be manually configured as follows:

# **HDCP Implementation**

HDCP link security logic is implemented in certain transmitters; unique keys are embedded in each chip as part of the solution. The security scheme is fully automatic and is handled completely by hardware.

# **Control for HDCP**

The host uses standard data structure elements to select the correct level of high definition content protection.

Table 28. Mapping of HDCP Data to TPI Register Bits

|                                                                              |                | T Data to 111 Register Dits                                                                                                                                                                                                                                                                                                                                                      |
|------------------------------------------------------------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Name                                                                         | Read/<br>Write | How to Derive from TPI Registers                                                                                                                                                                                                                                                                                                                                                 |
| ProtLevel Min (0) Max (1)                                                    | W              | The host writes this value to request that link security (HDCP) be enabled (1) or disabled (0).                                                                                                                                                                                                                                                                                  |
| ProtType None (0) HDCP (1)                                                   | R              | The host reads this value to determine whether HDCP is available on the attached monitor. The transmitter logic automatically detects whether the sink is HDCP-capable after a hot-plug event. The host must have requested and released the DDC bus at least once to trigger the automatic detection.                                                                           |
| Flags  Status Normal (0x00)  Link Lost (0x01)  Renegotiation Required (0x02) | R              | The host polls this value, or can be interrupted when this value changes.  Status Normal: The data link is operating according to the requested Protection Level.  Link Lost: The physical link has been interrupted (through cable detachment or error).  Renegotiation Required: During HDCP operation, an Ri mismatch has occurred requiring the host to re-request security. |
| ConnectorType DVI (0) HDMI (1)                                               | R              | The host reads this value to determine whether the attached sink device is DVI or HDMI. It reflects the value written to TPI $0x1A[0]$ .                                                                                                                                                                                                                                         |
| ProtectionLevel (Local/Extended)  No Link Protection (0)  Link Secure (1)    | R              | The host polls this value, or can be interrupted when the value changes.  Local Link: The link from the transmitter to the attached sink, whether display or repeater.  Extended Link: The link downstream from the attached repeater. If no repeater is attached, this value will always be 0.                                                                                  |
| HDCPFlags HDCPRepeater (0x01)                                                | R              | The host reads this value to determine whether the device is an HDCP repeater.                                                                                                                                                                                                                                                                                                   |
| BKey Bksv from attached device.                                              | R              | The host requests BKey to determine whether the HDCP keys are valid.                                                                                                                                                                                                                                                                                                             |

# **HDCP Operation**

Once a connection is made, video is being transmitted, and link video is stable, the host can request link security through TPI 0x2A[0]. All subsequent authentication is performed automatically, and the resulting security level is reflected in TPI 0x29[7:6]. Typically the process takes under 1s.

Once the link is authenticated, periodic link integrity checks take place every 128 frames. The time interval between checks is therefore roughly 2s, depending on whether 60 or 50Hz video is being supplied. Note that some resolutions run at lower frame rates (such as 24Hz) will create a corresponding slow-down in the frequency of the periodic checking. It is possible to enable intermediate Ri reading 0x2A[3] to satisfy the 2 s requirement for Ri checking.

Because any lengthy host use of the bus could conflict with HDCP link checks that occurs every 2 s, it is strongly recommended that the host clear its link security request (TPI 0x2A) whenever it wants to access the DDC bus.

#### **HDCP Data Structure**

The registers below reflect the information needed for the security interface. Use of these bits is detailed on the previous page. Additional information is provided below.

Link Status. These bits operate as follows; a status change can cause an interrupt if enabled.

Normal: The link is operating correctly; valid whether HDCP is running or not.

Link Lost: A hot plug or other event has caused the link to go down. A reset may be necessary to restore operation, if the logic is unable to return the connected link to Normal condition.

Renegotiation required: The link is still active, but some event (usually Ri mismatch) has caused HDCP to fail. The host must disable and then re-enabled the security request (TPI 0x2A[0]).

Link Encryption Suspended: The link is still active, but encryption has been turned off by clearing 0x2A[0]. This condition will return to Normal once 0x2A[0] is set to 1 again.

Note that the HDCP subsystem continues to keep the link authenticated (doing Ri checking) even after 0x2A[0] is switched from 1 to 0, so that subsequent security requests can return a "secure" status more quickly.

**Extended Link Protection Level.** TPI 0x29[7] indicates that the repeater authentication is complete. The bit should be ignored if the HDCP Repeater bit is not = 1.

→ Link Integrity Mode. If a downstream HDCP repeater is discovered, Link Integrity Mode bit TPI 0x1A[6] should be set to 1 (Dynamic). This setting forces the logic to re-authenticate any time the incoming clock resolution changes. This same setting will work even when the downstream sink is not a repeater; however, authentication may take slightly longer.

Repeater authentication takes place automatically after local link protection is established. The possible outcomes are:

- Success. Within 5s, TPI  $0x3D[7] \rightarrow 1$  to indicate the change in security status. Firmware then checks that TPI 0x29[7]=1, indicating that the extended link is now secure.
- Failure: After ~5s, if the extended link cannot be authenticated (typically due to lack of Ready status by the downstream HDCP repeater), TPI 0x3D[7] → 1 to indicate that authentication could not take place. TPI 0x29[7] remains at 0.

Using this mechanism, firmware can avoid implementing a timer – the logic design guarantees that TPI 0x3D[7] will be triggered as soon as the outcome is known.

 $\rightarrow$  Important Note: AV Mute must not be set before requesting authentication. If it is set, there will be no indication in TPI 0x3D[7] of the status outcome.

**Protection Type.** This bit indicates whether the automatic logic has detected an attached HDCP-capable device. The TPI subsystem will not attempt to detect an HDCP receiver until the host has requested and then released the DDC bus once after hot plug, and then turned on TMDS output to send valid clocks. Therefore, even if the host does not read the EDID immediately, it should still request and then release the DDC bus to trigger detection.

#### Silicon Image, Inc.

Access. All registers can be read either individually or in a burst.

The correct sequence for enabling or disabling HDCP is:

- Poll 0x29[1] until it indicates that HDCP is available; the Bksv values are only valid when 0x29[1] = 1.
- Write 0x2A[0] with the desired setting.
- Poll 0x2A[0] until it matches the setting just made.
- Poll 0x29[7:6] until they indicate the desired security level.

Note that TPI 0x29 may not be updated immediately after a cable connect event, due to the delay (max 1s) introduced by the automatic de-bounce logic. If desired, Interrupt Status register TPI 0x3D bits 2 and 0 can be read to verify the connection before reading TPI 0x29.

**Table 29. TPI Security Registers** 

| Offset           | Bit 7                                                                                    | Bit 6                                                              | Bit 5                                                                                                                     | Bit 4                                                   | Bit 3                                                                                  | Bit 2                                                                                                         | Bit 1                                         | Bit 0                                                                                        |
|------------------|------------------------------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|-----------------------------------------------|----------------------------------------------------------------------------------------------|
| 0x29             |                                                                                          |                                                                    |                                                                                                                           | QueryDa                                                 | ita (RO)                                                                               |                                                                                                               | . (                                           | 1                                                                                            |
|                  | Extended Link Protection Level (across repeaters) 0 - No link protection 1 - Link secure | Local Link Protection Level 0 – No link protection 1 – Link secure | 00 – N<br>01 – Li<br>10 – Renegoti<br>11 – Link                                                                           | Status Normal Ink Lost lation required Encryption ended | HDCP<br>Repeater<br>0 – No<br>1 – Yes                                                  | Connector<br>Type<br>Bit 2 + bit 0<br>work together:<br>0+0 - DVI<br>1+0 - HDMI<br>0+1 - Rsvd<br>1+1 - Future | Protection<br>Type<br>0 – None<br>1 – HDCP    | Connector<br>Type<br>Extension<br>See bit 2                                                  |
| <b>0x2A</b> [00] |                                                                                          |                                                                    |                                                                                                                           | ControlD                                                |                                                                                        |                                                                                                               |                                               |                                                                                              |
|                  | Rs                                                                                       | vd                                                                 | encryption disable 0 = encryption enabled if authenticati on succeded 1 = no HDCP encryption (even after authenticati on) | KSV<br>Forward<br>0 =<br>disable<br>1 =<br>enable       | Ri<br>Intermed<br>iate<br>Check<br>0 =<br>disable<br>1 =<br>enable                     | Ri Read<br>Twice<br>0 =<br>disable<br>1 =<br>enable                                                           | Ri Read<br>Format:<br>0 = normal<br>1 = short | Protection<br>Level<br>0 – Min (no<br>protection<br>needed)<br>1 – Max<br>(HDCP<br>required) |
| 0x2B             |                                                                                          |                                                                    | 1/2                                                                                                                       |                                                         | 1(RO)                                                                                  |                                                                                                               |                                               |                                                                                              |
| 0x2C             |                                                                                          |                                                                    | ,                                                                                                                         |                                                         | 2(RO)                                                                                  |                                                                                                               |                                               |                                                                                              |
| 0x2D             |                                                                                          |                                                                    | * X                                                                                                                       |                                                         | _3 (RO)                                                                                |                                                                                                               |                                               |                                                                                              |
| 0x2E<br>0x2F     |                                                                                          | $\mathcal{L}$                                                      |                                                                                                                           |                                                         | _4(RO)<br>_5(RO)                                                                       |                                                                                                               |                                               |                                                                                              |
| 0x2F<br>0xBB     | . 1                                                                                      |                                                                    |                                                                                                                           | OptionCon                                               |                                                                                        |                                                                                                               |                                               |                                                                                              |
| [76]             | Internal Use                                                                             | Internal Use                                                       | Internal Use                                                                                                              | Internal Use                                            | Ri Check                                                                               | Internal Use                                                                                                  | Internal Use                                  | Internal Use                                                                                 |
|                  | Write as 0                                                                               | Write as 1                                                         | Write as 1                                                                                                                | Write as 1                                              | Skip 0 – Enforce Ri check every 128 frames 1 – Allow up to two Ri checks to be skipped | Write as 1                                                                                                    | Write as 1                                    | Write as 0                                                                                   |

For SiI 9022A/9024A only: Always enable 0xBC = 0x01; 0xBD = 0x0A; 0xBE = 0x09 for HDCP to work in embedded mode with a Device\_Count = 0 condition before enabling video output or polling for HDCP availability.



### **Important Notes**

The automatic HDCP module expects firmware to follow a certain logical order in order to correctly sequence the HDCP events. Important considerations for this sequencing are noted below.

- **Initial Request/Grant Requirement.** On a hot plug event, host firmware requests and is granted the DDC bus for reading EDID. The bus must be requested, granted, and released at least once after any hot plug event (through TPI 0x1A). This action releases the bus from an initial hold state, allowing internal logic to access it as needed.
- **Triggering the Bksv/Bcaps Read.** After the host has read the EDID and determined an acceptable resolution, it starts sending video to the transmitter input. Once this video is stable, the host enables the TMDS output from the transmitter (again through TPI 0x1A). Turning on TMDS output triggers the logic to attempt to discover downstream HDCP devices, which require a TMDS clock before they become accessible. Only then can the Tx read Bcaps and Bksv.
- Causes of "Renegotiation Required". Once the host requests link security through 0x2A[0]=1, the DDC bus is tied up by the 1<sup>st</sup>, 2<sup>nd</sup>, and 3<sup>rd</sup> parts of the authentication process described in the HDCP specification. After the 1<sup>st</sup> part is complete, TPI 0x29[6]=1. After the 2<sup>nd</sup> part is complete, TPI 0x29[7]=1. The 3<sup>rd</sup> part is a recurring event, repeating every 128 frames. Interruption of any of these phases will result in TPI 0x29[5:4]=11, indicating Renegotiation Required. This would likely happen if an intentional external hack were taking place on the DDC bus to circumvent HDCP.
- Causes of "Link Encryption Suspended". Even when HDCP encryption is turned off through TPI 0x2A[0]=0, the logic will attempt to keep the link authenticated through periodic Ri checks. If no other DDC activity has interfered with an Ri check event, turning HDCP encryption back on will take effect immediately and the link will still be considered secure (no new authentication needed). But if some device takes over the DDC bus and prevents a periodic Ri check, the result is TPI 0x29[6:5]=11, Link Encryption Suspended.
- **ksv List Acquisition in Source Applications.** When the Tx is used in an HDMI Source system, the host uses a normal request/grant procedure to obtain control of the DDC bus, and then reads the downstream ksv lists for comparison against keys in the SRM. HDCP encryption and link integrity checking can be left enabled; a bus grant will arrive within 2s of the request, and the host can then retrieve and compare the ksv list.
- **ksv List Acquisition in Repeater Applications.** When the Tx is used in an HDMI Repeater system, the HDMI CTS restricts the amount of time allowed for loading the downstream ksv list into the upstream Rx FIFO and setting the Ready bit. TPI development firmware supplied by Silicon Image includes special "shortcut" routines for quickly and safely forcing a grant of the DDC bus, allowing the ksv list to be quickly acquired and loaded to the upstream Rx FIFO. Refer to the supplied firmware for details on this and other Repeater-related topics.

#### Ri Read (Available only on the SiI9136/9334.)

**Postponing the Ri Check.** There are times when the host would want to use the DDC bus while still keeping the link authenticated, but may not be able to return the bus in time for the next Ri check to take place. TPI 0xBB[3] is provided to allow extra time in this case. When set to 1, if the DDC bus is granted to the host, up to two Ri checks (coming at the usual 128 frame intervals) can be missed without triggering a Link Encryption Suspended or Renegotiation Required event. This bit can be set to 1 once, at initialization time, if desired.

**Ri Short Reads.** Enabled through TPI 0x2A[1] = 1, short read are done in order to minimize the number of bits that must be transferred for the link integrity check, a second short read format is supported. This access has an implicit offset address equal to 0x08, the starting location for Ri'. The short read format may be uniquely differentiated from combined reads by tracking STOP conditions (P) on the bus. Short reads are supported with auto-incrementing addresses and enabled by TPI Ri Read Format Register.

The following describe the formats of the Ri reads:

- A normal Ri read over the I2C bus is of the following format: <S> <Slave Address (7)> <W> <A> <Slave Offset (8)> <A> <S> <Slave Address (7)> <R> <A> <Read Data (8)> <A> <Read Data (8)> <Â> <P>
- A short Ri read over the I2C bus is of the following format: <S> <Slave Address (7)> <R> <A> <Read Data (8)> <A> <Read Data (8)> <A> <P>

Ri Reading Twice: Enable Ri checking at the time of Ri counter = 127. Without setting this bit, Ri check is performed at only counter = 0. Recommend to set this bit.

Ri Intermediate Check: Enable the intermediate check to also cause the Ri values to be checked at Ri counter 64.

# **Auxiliary HDCP Registers**

TPI supports HDCP repeater authentication and revocation through the simple interface described below.

#### **HDCP Info Register**

Identifies the support for HDCP revision 1.2. If this byte reads 00, HDCP is not supported in this device. However, if the byte is not zero, HDCP may still not be supported. Software must read and verify Aksv as described on the next page (TPI 0x36-3A) to verify HDCP capability.

**Access.** This register is accessed as a single byte.

Table 30. TPI HDCP Revision Data (RO)

| Ī | Offset | Bits  | Bit Field Description | Return value |
|---|--------|-------|-----------------------|--------------|
|   | 0x30   | [3:0] | HDCP Minor revision   | 0x02         |
|   |        | [7:4] | HDCP Major revision   | 0x01         |

#### V\* Value Select Register

" $V^*$  value" is the Silicon Image designation for the KSV values it has hashed together with the transmitter M0 value. The host reads the  $V^*$  value and compares it with its own calculated value to verify a match.

Write: Allows the host to select V\*0 to V\*4 for readback at offsets 0x32-35.

Read: The microcontroller needs some time to load the selected  $V^*$  values for reading. After the host writes this register to select the set of  $V^*$  values to be read, it must poll the 'ready' bit until it reads = 1 indicating that the  $V^*$  values are ready for reading.

**Authentication State.** This value returns the status of an internal state machine. It should **not** be used by the host for normal activities, as its timings depend on the system configuration. However, it can be convenient for use in HDCP debugging in the case of repeater authentication, where it will stay in the '11' state until all downstream devices have reported back as "ready".

**Downstream HDCP Device Count.** The transmitter supports a maximum of 16 downstream devices. This bit indicates whether this limit has been exceeded. It is only valid when the repeater authentication process has completed.

Access. This register is accessed as a single byte.

Table 31. TPI KSV and V\* Value Data (R/W)

| Offset | Bit 7                                                                                      | Bit 6          | Bit 5        | Bit 4         | Bit 3                                | Bit 2                | Bit 1                 | Bit 0 |  |
|--------|--------------------------------------------------------------------------------------------|----------------|--------------|---------------|--------------------------------------|----------------------|-----------------------|-------|--|
| 0x31   | Authentication State (RO)  00 – Auth. required  01 – Re-auth. required  10 – Authenticated |                | Rsvd for     | Downstream    | Selected V*                          |                      | V* Value Select       |       |  |
| [00]   |                                                                                            |                | internal use | Count (RO)    | Values Ready? 000 – H0 (RO) 001 – H1 |                      |                       |       |  |
|        |                                                                                            |                |              | 0 – Within Tx | ` ,                                  | 001 – H1<br>010 – H2 |                       |       |  |
|        |                                                                                            | auth. required | `(           | limit         | 1 – Yes                              |                      | 010 – 112<br>011 – H3 |       |  |
|        |                                                                                            |                |              | 1 – Exceeds   |                                      |                      | 100 - H4              |       |  |
|        |                                                                                            | 60             |              | Tx limit      |                                      | 101 – Rsvd           |                       |       |  |
|        |                                                                                            |                |              |               |                                      |                      | 11x - Rsvd            |       |  |

#### V\* Value Readback Registers

The host reads back the 32-bit value for the selected V\* value from these registers.

Access. Registers 0x32–0x35 must be accessed as a complete group using a burst read.

Table 32. TPI V\* Value Readback Data (RO)

| Offset | Bits  | Bit Field Description |
|--------|-------|-----------------------|
| 0x32   | [7:0] | V* Hx bits [7:0]      |
| 0x33   | [7:0] | V* Hx bits [15:8]     |
| 0x34   | [7:0] | V* Hx bits [23:16]    |
| 0x35   | [7:0] | V* Hx bits [31:24]    |

#### **Aksv Value Readback Registers**

The host reads back the 40-bit value for the transmitter Aksv from these registers. It must check the Aksv for 20 1s and 20 0s to verify that HDCP capability is available. A 9022A Tx will typically return the values 0x09, 0x00, 0x02, 0x02, 0x0A from these registers, indicating that it is not HDCP-capable.

Access. Registers 0x36–0x3A must be accessed as a complete group using a burst read.

Table 33. TPI Aksv Readback Data (RO)

| Offset | Bits  | Bit Field Description |  |  |  |  |  |  |
|--------|-------|-----------------------|--|--|--|--|--|--|
| 0x36   | [7:0] | AKSV_1                |  |  |  |  |  |  |
| 0x37   | [7:0] | AKSV_2                |  |  |  |  |  |  |
| 0x38   | [7:0] | AKSV_3                |  |  |  |  |  |  |
| 0x39   | [7:0] | AKSV_4                |  |  |  |  |  |  |
| 0x3A   | [7:0] | AKSV_5                |  |  |  |  |  |  |

### KSV List Forward (Available only on the SiI9136/9334.)

When KSV forwarding feature is disabled (0x2A[4] is 0) and a repeater is connected to the HDMI output, downstream KSV list is read first by hardware during  $2^{nd}$  authentication part of HDCP. Then firmware needs reading it second time to do KSV revocation (source case) or forward to upstream (repeater case). The reading usually occurs during HDCP part 3 when Ri check periodically occurs. Such reading may take significant time and violate 500 ms requirement for KSV list propagation (repeater case). KSV forwarding feature allows avoiding such problems.

Set 0x2A[4] to enable it. When enabled, hardware reads up to 16 KSV bytes into KSV FIFO. Firmware gets 0x3E[1] interrupt when the FIFO is not empty. The number of available bytes is indicated in 0x41[0...4]. The counter is decremented when a FIFO byte is read from 0x42. It is possible reading from this register in burst mode. If the FIFO is not full and there is data to read from the downstream device, hardware logic continues reading. Once last byte of the KSV list is read, 0x41[7] is set. Note. If downstream device is a repeater with zero KSV list, no 0x3E[1] interrupt occurs.

Table 34. TPI KSV Forward (RO)

| Offset | Bit 7                                                        | Bit 6 | Bit 5         | Bit 4 | Bit 3 | Bit 2             | Bit 1  | Bit 0 |
|--------|--------------------------------------------------------------|-------|---------------|-------|-------|-------------------|--------|-------|
| 0x41   | Last Byte<br>of KSV<br>FIFO<br>received<br>0 – No<br>1 – Yes | Rese  | erved         |       | Numbe | er of bytes in KS | V FIFO |       |
| 0x42   |                                                              |       | KSV FIFO Data |       |       |                   |        |       |

### Bcaps and Bstatus Readback Registers (Available only on the SiI9136/9334.)

Register 0x44 shows shadow downstream BCAPS registers read by hardware during HDCP part 1 and 2.

Table 35. TPI BCAPS (RO)

| Offset | Bit 7    | Bit 6      | Bit 5    | Bit 4 | Bit 3    | Bit 2 | Bit 1    | Bit 0          |
|--------|----------|------------|----------|-------|----------|-------|----------|----------------|
| 0x44   | HDMI     | Repeater   | KSV FIFO | FAST  | Reserved |       | 1.1      | Fast re-       |
|        | Reserved | Capability | Ready    |       |          |       | Features | authentication |

# Bstatus Readback Registers (Available only on the SiI9136/9334.)

In addition to assembling the KSV list, an HDCP Repeater propagates topology information upward through the connection tree to the HDCP Transmitter. An HDCP Repeater reports the topology status variables DEVICE\_COUNT and DEPTH. If the DEVICE COUNT is exceeded the Repeater asserts the MAX\_DEVS\_EXCEEDED status bit. If the computed DEPTH is exceeded the Repeater asserts the MAX\_CASCADE\_EXCEEDED status bit.

Table 36. TPI BSTATUS (RO)

| Offset | Bit 7                                     | Bit 6    | Bit 5 | Bit 4                               | Bit 3                                           | Bit 2 | Bit 1 | Bit 0 |
|--------|-------------------------------------------|----------|-------|-------------------------------------|-------------------------------------------------|-------|-------|-------|
| 0x45   | MAX DEVS<br>EXCEEDED<br>0 – No<br>1 – Yes |          |       |                                     | Device Count                                    |       |       |       |
| 0x46   | 1 100                                     | Reserved |       | HDMI<br>Mode<br>0 – DVI<br>1 – HDMI | MAX<br>CASCADE<br>EXCEEDED<br>0 - No<br>1 - Yes |       | Depth | 5     |

# Appendix A – SiI9020 Tx Compatible Mode

The SiI9022/9024/9022A/9024A Tx devices implement an SiI9020 Tx Compatible Mode, in which the device defaults to register mapping that is nearly identical to the SiI9020 Tx.

Note: When the chip is left in Compatible mode, the TPI register set is not accessible.

#### SiI9020-9022-9022A Transmitter Mode Differences

The current document describes only the Transmitter Programming Interface (TPI) programming model. For new designs, use of the SiI9020 transmitter backwards-compatible register set is discouraged, since TPI is much more efficient and automated. Moreover, the HDCP functionality of the SiI9024/9024A transmitter can be accessed only through the TPI register set (since the SiI9020 transmitter did not offer HDCP).

The chip defaults to SiI9020 transmitter register-compatible mode to allow operation with firmware in existing designs. The following document is required only if the SiI9020 transmitter backwards-compatible programming mode is used.

• SiI-PR-0020: SiI9020 HDMI PanelLink Transmitter Programmer's Reference

In addition, some register programming changes are required as described below.

## **PLL Settings**

Due to the newly designed PLL used in the SiI9022/9022A transmitter, a small amount of additional register programming is required to set the PLL according to the input bus clocking. Table A - 1 lists the settings.

TCLKSEL refers to existing bits in the SiI9020 transmitter registers, and is selected as before. ACLKCNT, HLFCLKEN, and CLKMULTCTL must then be set according to both TCLKSEL and the input pixel clock range being used.

Note that when using the TPI mode of operation, the logic sets PLL registers automatically according to the pixel frequency programmed, so the registers shown below are not used.

Input Clock **TCLKSEL Input Pixel** ACLKCNT HLFCLKEN **CLKMULTCTL** Resulting PLL Clock Multiplier Clock (MHz) (MHz) 0x82[6:5] 0x84[5:4] 0x84[1] 0x83[5:4] < 36 00 1 01 125-166 36 - 7800 00 0 91 - 1780.5x00 01 0 00 78 - 13998 - 178> 139 10 0 00 115-140 00 0 01 125-166 < 36 36 - 7101 0 01 91 - 16201 1x71 - 10410 0 01 118-158 > 104 11 0 01 104-168 01 0 10 < 36 125-166 2x10 >36 - 53 10 0 10 122-162 > 53 11 0 10 107-156 11 0 11 107-161 always

Table A - 1. PLL Programming Registers – SiI9020 Mode Only (R/W)

**Note:** These are Device 0x72 Registers.

#### Silicon Image, Inc.

Table A - 2. summarizes the SiI9022/9022A transmitter PLL-related register changes to the original SiI9020 transmitter register set.

Bit 7 Bit 5 Bit 4 Bit 3 Bit 2 Bit 6 Bit 1 Bit 0 Legacy Mode Offset 0x82 SiI9020 Tx Compatibility PLL Programming Register 1 [00] **TCLKSEL** Rsvd Rsvd Rsvd Rsvd Rsvd Refer to Table A - 1 0x83 SiI9020 Tx Compatibility PLL Programming Register 2 [00] Rsvd Rsvd CLKMULTCTL Rsvd Rsvd Refer to Table A - 1 0x84 SiI9020 Tx Compatibility PLL Programming Register 3 [00] Rsvd Rsvd ACLKCNT Rsvd Rsvd **HLFCLKEN** Rsvd Refer to Table A - 1 Refer to Table A - 1

Table A - 2. SiI9020 Tansmitter Mode Difference – PLL Setup (R/W)

#### Notes

- 1. These are Device 0x72 Registers, and should be changed using a **read-modify-write** sequence **only**
- 2. Writing TCLKSEL in 0x82 must be done **before** writing 0x83 or 0x84.

#### **DDC Bus Request/Grant**

The SiI9020 transmitter logic included a bus mastering  $I^2C$  interface that required preprogramming for background transfer of EDID information to and from its internal buffers. However, this mechanism limited the speed of transfers to well under 100kHz and imposed unnecessary overhead on the transaction.

Therefore, the bus mastering logic was improved for the SiI9022/9022A transmitter to use a direct access mechanism. The host device must simply request bus access and then perform data transfers directly with the end device, with the SiI9022/9022A transmitter logic acting as a "pass-through" buffer. The bus can run up to 400kHz depending on the capabilities of the host and slave devices (but should not exceed the 100kHz HDMI limit). I<sup>2</sup>C clock stretching by slave devices is fully supported (by passing the clock stretch back to the master as required).

To use the new direct access mode of DDC operation: The host device uses the DDC bus Request control and Grant status bits as follows.

- 1. Before performing a DDC bus access, write 0x72:0xC7 = 0x87 to request the bus and switch to the output DDC bus instead of the internal registers.
- 2. Execute all DDC transfers directly. No internal registers are accessible at this time, except for writes to 0x72:0xC7.
- 3. When finished, write 0x72:0xC7 = 0x80 to clear the request and switch back to internal registers.

Note that no ACK will be returned to this write. Writing or reading any device 0x72 register will disconnect local  $I^2C$  from the external DDC bus, but it is important to perform this specific 0x72:0xC7 write to remove the bus request.

#### Video Black Mode

The SiI9022/9022A transmitter provides a means of driving out all-black video output as long as it is receiving valid clock and sync inputs. 0x72:0xC7[5] controls this feature.

Table A - 3. summarizes the SiI9022/9022A transmitter register changes to the original SiI9020 transmitter register set.

Table A - 3. SiI9020 Transmitter Mode Difference – Request/Grant/Black Mode (R/W)

| Legacy<br>Mode<br>Offset | Bit 7        | Bit 6 | Bit 5       | Bit 4         | Bit 3              | Bit 2                     | Bit 1       | Bit 0           |
|--------------------------|--------------|-------|-------------|---------------|--------------------|---------------------------|-------------|-----------------|
| 0xC7                     |              |       | S           | iI9020 Tx Com | patibility Registe | er                        |             |                 |
| [80]                     | TPI Register | Rsvd  | Video Black | Rsvd          | Rsvd               | I <sup>2</sup> C Switch – | DDC Grant   | DDC Request     |
|                          | Set          |       | Mode        |               |                    | Local I <sup>2</sup> C    | (RO)        | 0 – Bus not     |
|                          | 1 – Disable  |       | 0 – Normal  |               | $O_{\bullet}$      | accesses:                 | 0 – Tx owns | needed          |
|                          | (9020 mode)  |       | 1 – Force   |               |                    | 0 – Internal              | DDC bus     | 1 – Host        |
|                          | 0 – Enable   |       | video to    |               | A 4                | registers                 | 1 – Host is | requests use of |
|                          | (9022/9024   |       | black       |               |                    | 1 – DDC                   | granted DDC | DDC bus         |
|                          | TPI mode)    |       |             | ( ) -         |                    |                           | bus access  |                 |

**Note:** This is a Device 0x72 register.

### **Power-Down Register**

The SiI9022/9022A transmitter HDMI core exhibits reduced power consumption over the SiI9020 transmitter. The new circuitry that is implemented changes how the chip behaves in low power modes, in that clearing PDOSC# or PDTOT# disables further local I<sup>2</sup>C bus access.

Therefore, after PDOSC# or PDTOT# are set to 0, hardware reset must be applied before attempting to use the local I<sup>2</sup>C bus for register or DDC bus access.

Table A - 4. Power-Down Register for SiI9020 Transmitter Register-Compatible Mode (R/W)

| Legacy         | Bit 7 | Bit 6 | Bit 5 | Bit 4           | Bit 3           | Bit 2        | Bit 1            | Bit 0      |
|----------------|-------|-------|-------|-----------------|-----------------|--------------|------------------|------------|
| Mode<br>Offset |       |       |       |                 |                 |              |                  |            |
| 0x3D           |       |       | S     | SiI9022 Tx Powe | er Down Registe | er           |                  |            |
| [17]           | Rsvd  | Rsvd  | Rsvd  | Factory Test    | Factory Test    | PDIDCK#      | PDOSC#           | PDTOT#     |
|                |       |       |       | bit             | bit             | 0 – Gate off | 0 – Disable      | 0 – Power  |
|                |       |       |       | Must be 1       | Must be 0 for   | IDCK signal  | internal         | down TMDS, |
|                |       |       |       | for normal      | normal          | to disable   | oscillator       | gate off   |
|                |       |       |       | operation       | operation       | video clock  | clock to digital |            |
|                |       |       |       | 71              |                 | based logic  | core             | 1 – Normal |
|                |       |       | \ X \ |                 |                 | 1 – Normal   | 1 – Normal       | operation  |
|                |       |       |       |                 |                 | operation    | operation        |            |

Note: This is a Device 0x7A register.

#### **Transmitter Mode after Reset**

The SiI9022A transmitter core is modified for better performance compared to both the SiI9020 and SiI9022 devices. However, unlike these previous devices, the SiI9022A device powers up after a reset in a state where the TMDS transmitter is active. This function is controlled through existing Compatible Mode register bit 0x08[0], which defaults to 1 in the SiI9022A part after reset.

If it is desired to reset the device but then enter the lowest power standby state, write 0x08[0]=0 to turn off the transmitter core output.

# Appendix B – Mobile HD Link

Silicon Image Mobile HD Link solutions carry digital video and audio streams over a reduced pin-count TMDS interface, but in a format that is readily converted for 100% HDMI compatibility.

The transmitter device and receiver/bridge device appear to software as an integral unit, in that remote functions such as CEC and EDID access appear to be local. Therefore, this appendix describes operation in terms of the combined transmitter-receiver solution.

Table B - 1. Mobile HD Link Products Described in this Appendix

| HDCP-enabled<br>Version | Non HDCP-enabled<br>Version | Input Interface |
|-------------------------|-----------------------------|-----------------|
| SiI9222 Tx              | SiI9226 Tx                  | RGB             |
| SiI9232 Tx              | SiI9236 Tx                  | RGB             |

**Note:** Data on Mobile HD Link products and features is provided here as **advance** information, and is therefore subject to change. Contact your Silicon Image representative for updates.

Figure B - 1 illustrates a typical Mobile HD Link implementation.



Figure B - 1. Typical Mobile HD Link Solution

**Summary of Differences between HDMI and Mobile HD Link families.** Designs using TPI and CPI with the SiI9022/24 Tx adapt to the SiI922x or SiI923x transmitter with virtually no software changes. The default TPI and CPI register sets have been maintained from the SiI9022/24 Tx. The main differences in support from a programmer's point of view are summarized as follows.

- The host decides when to allow the transmitter to "discover" a connected device, and must follow an explicit sequence to complete this discovery process.
- Most TPI register functionality is meaningful only when the transmitter is connected to the receiver/bridge device. Therefore, software must monitor Hot Plug status information using TPI 0x3C and 0x3D (either by hardware interrupt or by polling methods) before programming other TPI information.
- A non maskable interrupt is added to alert the host to unrecoverable cable connection errors.
- An interface known as the CTRL bus is used to transparently exchange DDC and CEC information with the remote Mobile HD Link receiver. A small amount of initialization and operational programming is required for the CTRL bus.
- The older SiI9020-compatible register interface is no longer supported.
- The I<sup>2</sup>S audio input option is limited to two channels.

These differences are described in detail in the following sections.

# **Detailed Programming Requirements**

The following programming information is in addition to the TPI programming described in the main part of this document.

# I<sup>2</sup>C Requirements

In the typical transmitter environment, the host masters the TPI/CPI/input DDC  $I^2C$  interface, and the transmitter-receiver combination masters the output DDC  $I^2C$  interface, as illustrated in Figure B - 1.

- Host TPI/CPI/input DDC I<sup>2</sup>C Interface. The Tx implements this slave interface, mastered by the host. The host serially transmits and receives data over this bus, which implements a register interface structure where the host writes video mode control data and reads back connection status information.
  - This link also allows host inter-chip register read/write access to the Mobile HD Link Bridge register set, through the Private Channel of the CTRL bus (see below).
- Output DDC I<sup>2</sup>C Interface. The Mobile HD Link Tx and Bridge together implement this interface so that is appears as a pass-through connection from the host to the DDC bus of the HDMI TV. The transmitter has the ability to block the graphics host from accessing this bus, and also monitors the bus for activity to prevent breaking an active connection.

# **Identification**

The ID registers return the TPI family device ID and TPI revision ID. The ID registers are listed in the tables below.

Access. These registers are accessed as single bytes.

Table B - 2. TPI Identification Registers (RO)

| Offset | Bit 7                   | Bit 6                | Bit 5 | Bit 4    | Bit 3            | Bit 2    | Bit 1 | Bit 0 |  |  |
|--------|-------------------------|----------------------|-------|----------|------------------|----------|-------|-------|--|--|
| 0x1B   |                         | TPI Family Device ID |       |          |                  |          |       |       |  |  |
| 0x1C   | Rsvd Device Revision ID |                      |       |          |                  |          |       |       |  |  |
| 0x1D   | Rsvd = 0                |                      |       | TPI revi | sion level (majo | r.minor) |       |       |  |  |

Table B - 3. Device ID Information

| Device     | Input Type | Device ID<br>TPI 0x1B | TPI Revision ID<br>TPI 0x1D | Sub-Identifier* at 0xBE<br>with 0xBC=01, 0xBD=02 | HDCP Available?<br>TPI 0x30 |
|------------|------------|-----------------------|-----------------------------|--------------------------------------------------|-----------------------------|
| SiI9226 Tx | RGB        | $0xB0^1$              | $0x00^{2}$                  | 0x22                                             | No                          |
| SiI9222 Tx | RGB        | $0xB0^1$              | $0x00^{2}$                  | 0x22                                             | Yes                         |
| SiI9232 Tx | RGB        | 0xB2                  | 0x00                        | 0x32                                             | Yes                         |
| SiI9236 Tx | RGB        | 0xB2                  | 0x00                        | 0x32                                             | No                          |

#### Notes

1. The Device ID of 0xB0 is also shared with the Silicon Image SiI9022/24 Tx. Following the sequence below enables the host to uniquely identify the transmitter.

# **Initialization**

Mobile HD Link transmitters typically share their connector pins with other signals, and therefore must stay off the buses until a connection with a receiver is requested. Once a connection is needed, the transmitter and bridge devices must go through an automatic Discovery process for each of them to verify that a compatible Mobile HD Link device is connected on the other end.

### Reset

For Reset of the SiI9222/9226 Tx, the transmitter host processor must always follow this procedure.

- 1. Drive the CSCL input pin low.
- 2. Drive the RST# input low, hold for at least 50us, then release.
- 3. Release CSCL and program the chip as usual.

This process forces the device to come up in a mode where the TMDS and CTRL pins will not drive the bus.

### **Connection and Discovery**

To enable the Tx device to communicate with an attached bridge device, the Tx must "discover" the bridge. The host processor initiates this process as follows.

- 1. Write TPI 0x1E[4]=1. This bit enables the CTRL pin to drive out, and starts the Discovery process. Refer to Table B 6.
- 2. Read the Link Control Bus Status Register 0x0A[0] to verify that the Control Bus is connected. This bit is located in the Link Control Bus register space. Refer to the Link Control Bus Programmer's Reference, SiI-PR-0031, for information.

# **CTRL Bus Configuration**

An additional step is required in the program flow for Mobile HD Link devices under "Hot Plug Service".

Hot Plug Service. Until a device is attached, the host just monitors the connection status either through interrupts or by polling. The host software waits for an attached Sink hot plug event, and then:

- <u>Initializes the Bridge CTRL bus registers</u>
- Reads the downstream Sink EDID information
- Sends active video corresponding to the Sink capabilities, and selects DVI or HDMI mode, depending on the EDID information found
- Sets the subsystem to Operational (D0) state.

The Tx and Bridge together implement the CTRL Bus protocol across the CTRL pin, to transparently perform EDID reads, CEC exchanges, and various status information exchanges.

### **Initializing the CTRL Bus Registers**

The host microcontroller, and optionally the bridge microcontroller as well, have the ability to carry out additional communication through the CTRL bus interface using the Private Channel registers. The full set of Private Channel registers is not documented here; contact Silicon Image for additional information.

However, the Tx host must minimally set up the CEC Logical Address using the Private Channel registers. This process is explained below.

 $I^2C$  Access Address. The  $I^2C$  address used to access the CTRL bus registers from the Tx is 0xC8. An alternate address of 0xCC is available, selected by strap setting as described in the specific data sheet for the chip.

Two Tx offset addresses are listed. Tx0 refers to the Primary connection on a Bridge chip, and Tx1 to the Secondary connection. In general, only Tx0 is available.

Offset (device 0xC8) Bit 7 Bit 3 Bit 6 Bit 5 Bit 4 Bit 2 Bit 1 Bit 0 TX0 TX1 **Private Channel Execution Control Register** Set only one bit at a time. Once executed, these bits are self-clearing. Forward Opcode 0x120x520=No action 1=Execute **Command Opcode Register** 0x13 0x53 Forwarded Opcodes. Before triggering a forwarding action (0x12[0]=1), the local host writes the opcode here.

Table B - 4. CTRL Bus - Command Registers

Table B - 5. CTRL Bus - Command Definitions

| Code | Command       | Description                           |
|------|---------------|---------------------------------------|
| 0x66 | SET_CEC_LADDR | Set CEC Logical Address and valid bit |
| 0x67 | GET_CEC_LADDR | Get CEC Logical Address and valid bit |

The typical programming sequence would be as follows.

Write (to I<sup>2</sup>C Device 0xC8):

#### **Transmitter Power State**

Mobile HD Link devices support ACPI-type power state control through the standard TPI register described elsewhere in this document. Refer to the Data Sheet for information on the various power savings that can be achieved at each level of ACPI power states D0, D2, and D3. Transition from D0 to any other state requires only a write to the Power\_state[1:0] bits.

For the D3 power state, there are two power scenarios possible depending on the system design.

- Attached State. If the cable is plugged in, simply selecting D3 state will result in the lowest power.
- Unattached State. If cable is unplugged, selecting D3 state alone will not result in the lowest power state. Instead, the sequence should be:
  - a. Drive CSCL low
  - b. Assert and then release Reset
  - c. Release CSCL

Selecting D3 state will now leave the chip in its lowest power state. Subsequently leaving D3 state will require a Reset with CSCL released (not driven low).

Access. This register is accessed as a single byte.

Table B - 6. TPI Device Power State Control Data (R/W)

| Offset | Bit 7 | Bit 6                                   | Bit 5 | Bit 4         | Bit 3 | Bit 2 | Bit 1         | Bit 0    |
|--------|-------|-----------------------------------------|-------|---------------|-------|-------|---------------|----------|
| 0x1E   |       | Rsvd                                    |       | CTRL Pin      | Rsvd  | Rsvd  | Tx Po         | ower_    |
| [02]   |       |                                         |       | Control       |       |       | State         | [1:0]    |
|        |       |                                         | M.    | 0 = Tri-state |       |       | 00, 01 =      | D0 state |
|        |       |                                         |       | 1 = Driven    |       |       | (full op      | eration) |
|        |       |                                         | (     | by Tx and     |       |       | $10 = \Gamma$ | 22 state |
|        |       |                                         | , X,  | Bridge as     |       |       | (standb       | y mode)  |
|        |       | $\mathcal{L}(\mathcal{L}(\mathcal{L}))$ |       | needed        |       |       | 11 = D3 state |          |
|        |       | X                                       |       |               |       |       | (shutdov      | vn mode) |

CTRL Pin Control. The CTRL signal on the mobile connector may be shared with other device signals. When cleared to 0, the CTRL Pin Control bit forces the Tx to tri-state its CTRL drive output, leaving the connector signal free for other compatible uses. This bit has an effect only after the Unattached State sequence above has been followed (without going to D3 state). Doing so leaves the CTRL pin tri-stated by default, which also prevents DDC bus usage. To subsequently resume normal operation with full DDC bus functionality available, the host would need to write this bit to 1.

# **Maximum Speed Limitations**

The output frequency of the TMDS clock is the product of the input clock frequency, the TClkSel setting, and the 3x Mobile HD Link encoding multiplier. The system software engineer must ensure that the resulting frequency does not exceed the operational limits of the chip (225MHz). If such a multiplier is selected and results in excessive operating speed, the chip state machines on both the transmitter and bridge may lock up. This situation is recoverable only by a hardware reset of each component.

# **Interrupt Service**

Because the Mobile HD Link establishes a "virtual" link from the host to the HDMI interface, certain ones of its TPI-level interrupts represent multiple underlying sources within the Internal Register set.

## TPI 0x3D[0]: Hot Plug/Connection Event

The TPI 0x3D[0] event will be indicated when any of the Internal Event bits below are enabled to generate an interrupt.

- 1. Virtual HPD Event in Internal Register bit 0x71[6]. This event is always enabled.
- 2. Events in Internal Register bits 0x74[6:2]; the corresponding bit in 0x78[6:2] must be enabled generate INT.
- 3. The CTRL Bus Heartbeat Failure Monitor in Internal Register 0x74[7]. This bit simply reflects the status of bit CTRL 0x1E[3] (in the 0xC8 register space).

Write 1 to the appropriate register bit to clear the corresponding event pending status. In the case of the CTRL Bus Heartbeat Failure Monitor event, use CTRL 0x1E[3] to clear the event. Refer to the *Link Control Bus Programmer's Reference* (SiI-PR-1031) for information.

**Internal** Registers Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 0 Bit 7 Bit 1 available at 0xBE when: Interrupt Status Register (R/W) Write '1' to clear pending status 0xBC=**00** 0xBD=71Virtual HPD [00] Event Pending (INT always enabled)  $0 = N_0$ 1 = YesInterrupt Status Register (R/W) 0xBC=00Write '1' to clear pending status 0xBD=**74 VBUS** Ctrl BUS USB Mode CTRL. MHD Mode [00] Heartbeat Staying low Lockout Established Established failure (RO) after MHD Window Event Event established Started Event pending pending Use CTRL and cable pending 1E[3] to clear 0 = No0 = Nodisconnected (device 0xC8) 0 = No1 = Yes1 = YesEvent 1 = Yespending 0 = No1 = YesInterrupt Enable Register (R/W) 0xBC=**00** 0 = Disable0 = Disable0 = Disable0 = Disable0 = Disable0xBD=781 = Enable1 = Enable1 = Enable1 = Enable1 = Enable[00]

Table B - 7. Connection Event Triggers

#### TPI 0x3D[1]: RxSense Event or CTRL Bus Error

The TPI 0x3D[1] event will be indicated when any of the Internal Event bits below are enabled to generate an interrupt.

- 1. Internal Register RxSense Event (see below). This event is always enabled.
- 2. CTRL Bus register bits 0x08[7:5], 0x08[2:0], 0x1E[4], 0x1E[2:1]. These bits are in the 0xC8 device space. Refer to the *Link Control Bus Programmer's Reference* (SiI-PR-1031) for information.

Write 1 to the appropriate register group to clear the corresponding event pending status.

Table B - 8. CTRL Bus Error Event Triggers

| Internal Registers available at 0xBE when: | Bit 7 | Bit 6 | Bit 5                                                         | Bit 4                                | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|--------------------------------------------|-------|-------|---------------------------------------------------------------|--------------------------------------|-------|-------|-------|-------|
| 0xBC= <b>00</b>                            |       |       |                                                               | nterrupt Status<br>Write '1' to clea |       |       | • (   |       |
| 0xBD= <b>71</b><br>[00]                    |       |       | RxSense Event Pending (INT always enabled) $0 = No$ $1 = Yes$ |                                      |       | X     | 57    |       |

### TPI 0x3D[2]: CTRL Bus Transaction Event

The TPI 0x3D[2] event will be indicated when any of the Internal Event bits below are enabled to generate an interrupt. This register bit has a dual function, controlled by TPI 0x3C[2], which must be set to 1 to use the CTRL bus interrupt monitoring function.

- 1. CTRL Bus (device 0xC8) registers 20 to 23; bits must be enabled to generate INT
- 2. CTRL Bus register bits 0x08[4:3] or 0x0E[0]; bits must be enabled to generate INT.

Write 1 to the appropriate register group to clear the corresponding event pending status.

### Non Maskable Interrupt

The Interrupt Status register for the SiI922x Tx implements a special non maskable interrupt function for Mobile HD Link devices.

Table B - 9. TPI Interrupt Status (R/W)

| Offset | Bit 7          | Bit 6          | Bit 5            | Bit 4          | Bit 3            | Bit 2           | Bit 1          | Bit 0         |
|--------|----------------|----------------|------------------|----------------|------------------|-----------------|----------------|---------------|
| 0x3D   | HDCP           | HDCP V*        | Security         | Audio Error    | Rx Sense or      | Hot Plug pin    | Receiver       | Hot Plug      |
| [00]   | Authentication | Value ready    | Status           | Event          | CPI Event        | current state   | Sense event    | event pending |
|        | status change  | event          | Change           | pending        | pending state    | (RO)            | pending        | 0 – No        |
|        | event pending  | pending        | event            | 0 - No         | (RO)             | 0 - Low         | 0 - No         | 1 - Yes       |
|        | 0 – No         | 0 – No         | pending          | 1 - Yes        | 0 – No Rx        | 1 – High        | 1 – Yes        |               |
|        | 1 – Yes        | 1 – Yes        | 0 - No           |                | sensed/CPI       |                 |                |               |
|        |                |                | 1 – Yes          |                | 1 – Powered      |                 |                |               |
|        |                |                |                  |                | Rx attached/     |                 |                |               |
|        |                |                |                  |                | CPI event        |                 |                |               |
|        |                |                |                  |                | pending          |                 |                |               |
|        | <b>←</b> 1     | Non Maskable l | Interrupt (SiI92 | 2x Tx only): B | yte returns 0xFF | (cleared only b | y hardware Res | et)>          |

**Non Maskable Interrupt (SiI922x Tx only).** Should an unrecoverable condition arise, TPI 0x3D will return 0xFF. This value (all interrupts triggered at once) indicates an error on the CTRL bus, typically due to poor connectivity. The only correct host response to a Non Maskable Interrupt is to perform a hardware reset to the chip, and to then re-initialize it.

# Appendix C – HDMI 1.4 HEAC Support

The SiI9334 Tx offers HDMI 1.4 Ethernet and Audio Return Channel (HEAC) features.

- The Audio Return Channel (ARC) allows the transmitter to accept S/PDIF audio input from the downstream HDMI 1.4 receiver device.
- The Home Ethernet Channel (HEC) allows the transmitter to pass Ethernet signalling to/from the downstream HDMI 1.4 receiver device.

These features are configured and enabled through the following registers.

 $I^2C$  Access Addresses. The  $I^2C$  address used to access the HEAC registers is 0x90. The logic can optionally respond at address 0x94 depending on the CI2CA hardware strap setting described in the transmitter Data Sheet.

**Table C - 1. HEAC Module Configuration 1 (R/W)** 

|                        |                                      |                                                         |                                                       |                                      | 7                                  |                                                        | 71.1                                         | 74.0                                                                        |  |  |  |
|------------------------|--------------------------------------|---------------------------------------------------------|-------------------------------------------------------|--------------------------------------|------------------------------------|--------------------------------------------------------|----------------------------------------------|-----------------------------------------------------------------------------|--|--|--|
| Addr<br>0x90<br>Offset | Bit 7                                | Bit 6                                                   | Bit 5                                                 | Bit 4                                | Bit 3                              | Bit 2                                                  | Bit 1                                        | Bit 0                                                                       |  |  |  |
|                        | H                                    |                                                         |                                                       |                                      | must be set whe                    |                                                        |                                              |                                                                             |  |  |  |
| <b>0x04</b> [00]       | Internal Test Use Write as 1 always. | 0.1                                                     | bias current cali<br>HEAC module.<br>gram setting = 0 |                                      |                                    | tage reference of<br>HEAC module.<br>gram setting – 01 |                                              | Band gap voltage reference 0 – Disable 1 – Enable                           |  |  |  |
| <b>0x05</b> [00]       | Rs                                   | Rsvd HEAC termination control setting Program = 0b00101 |                                                       |                                      |                                    |                                                        |                                              |                                                                             |  |  |  |
|                        |                                      |                                                         |                                                       |                                      | ontrol Group                       |                                                        |                                              |                                                                             |  |  |  |
| <b>0x08</b> [00]       | Rsvd                                 |                                                         | Progr                                                 | x input coarse g<br>ram setting = 0b |                                    | 2                                                      | Rsvd                                         | Ethernet Tx<br>input<br>0 – Disable<br>1 – Enable                           |  |  |  |
| <b>0x09</b><br>[00]    |                                      |                                                         | Rsvd                                                  |                                      |                                    | HEAC Differential mode driver 0 – Disable 1 – Enable   | Rs                                           | svd                                                                         |  |  |  |
| <b>0x0C</b> [00]       | Rsvd                                 |                                                         | M,                                                    |                                      | tput gain control<br>ng = 0bxxxxxx |                                                        |                                              | Rsvd                                                                        |  |  |  |
| <b>0x0D</b> [00]       |                                      | 40                                                      |                                                       | Rsvd                                 |                                    |                                                        |                                              | Ethernet<br>driver<br>0 – Disable<br>1 – Enable                             |  |  |  |
| 0x10<br>[00]           |                                      |                                                         |                                                       | R                                    | svd                                |                                                        |                                              |                                                                             |  |  |  |
| <b>0x11</b> [00]       |                                      |                                                         | Rsvd                                                  |                                      |                                    | Not used in<br>Evita<br>Write as 1<br>always           | Not used in<br>Evita<br>Write as 0<br>always | Differential<br>resistor enable<br>0 – Single<br>Mode<br>1 – Common<br>Mode |  |  |  |

Table C - 2. HEAC Module Configuration 2 (R/W)

| Addr<br>0x90<br>Offset | Bit 7                                                               | Bit 6                                                           | Bit 5                      | Bit 4                           | Bit 3              | Bit 2                                                               | Bit 1                                                                | Bit 0                                                               |  |  |
|------------------------|---------------------------------------------------------------------|-----------------------------------------------------------------|----------------------------|---------------------------------|--------------------|---------------------------------------------------------------------|----------------------------------------------------------------------|---------------------------------------------------------------------|--|--|
|                        |                                                                     |                                                                 |                            | <b>Ethernet Full</b>            | Duplex Group       |                                                                     | •                                                                    |                                                                     |  |  |
| <b>0x0A</b> [00]       |                                                                     |                                                                 | Rsvd                       |                                 |                    | HEAC receiver full duplex normal gain path mute 1 – Normal 0 - Mute | HEAC receiver full duplex reduced gain path mute 1 – Normal 0 - Mute | HEAC receiver full duplex Ethernet operation 0 – Disable 1 – Enable |  |  |
| 0x0B                   | Rsvd                                                                |                                                                 | HEAC recei                 | ver full duplex                 | state differential | gain control                                                        |                                                                      | Ethernet RX                                                         |  |  |
| [00]                   |                                                                     |                                                                 | Program setting = 0b0xxxxx |                                 |                    |                                                                     |                                                                      |                                                                     |  |  |
| <b>0x12</b> [00]       | ARC output<br>selection<br>0 – Single<br>Mode<br>1 – Common<br>Mode | ARC self<br>biasing<br>0 – Common<br>Mode<br>1 – Single<br>Mode |                            | HEAC                            |                    | plex stage slew<br>ng = 0b000000                                    | control                                                              |                                                                     |  |  |
| <b>0x0E</b> [00]       | Rsvd                                                                |                                                                 | Progr                      | IF output gain cam setting = 0b |                    |                                                                     | Rsvd                                                                 | ARC sink<br>S/PDIF output<br>gain<br>0 – Disable<br>1 – Enable      |  |  |
| <b>0x0F</b> [00]       |                                                                     |                                                                 | Rsvd                       | (0)                             | 000                | ARC sink<br>S/PDIF output<br>driver<br>0 – Disable<br>1 – Enable    | Rs                                                                   | vd                                                                  |  |  |

Start by writing (to I<sup>2</sup>C Device offset 0x90) the following register values:

```
// Enable band gap and program reference value
    1. 0x04 = 0xC9
                                 // Enable termination and program value
    2. 0x05 = 0x0B
                                 // Not used, program to 0x00
    3. 0x06 = 0x00
                                 // Not used, program to 0x00
    4. 0x07 = 0x00
                                 // Enable HEAC differential mode driver
    5. 0x09 = 0x04
    6. 0x11 = 0x05 [0x04]
                                 // Program setting recommended
    7. 0x12 = 0x80 [0x40]
                                 // ARC output selection / self bias and slew rate
To continue to configure HEC:
    8. 0x08 = 0x21 (0x00)
                                 // Enable Ethernet TX input and program gain
    9. 0x0A = 0x05 (0x00)
                                 // Enable full duplex Ethernet operation
    10.0x0B = 0x7F(0x00)
                                 // Enable Ethernet RX output and program full duplex differential gain
    11.0x0C = 0x7E (0x00)
                                 // Set Ethernet RX output gain
    12.0x0D = 0x01 (0x00)
                                 // Enable Ethernet driver
    13.0x10 = 0x00
                                 // RSVD
    14. 0x0E = 0x00
                                 // Disable SPDIF output gain
    15. 0x0F = 0x00
                                 // Disable SPDIF output driver
To continue to configure ARC:
    16.0x0E = 0x09 [0x39]
                                 // Enable SPDIF output and program gain
    17.0x0F = 0x04
                                 // Enable SPDIF output path driver
```

#### Note:

Write values shown in ( ) are for either ARC CM or SM

Write values shown in [] are for ARC SM only

### **Example 1.** To configure for ARC Common Mode with HEC:

- 1. 0x04 = 0xC9
- 2. 0x05 = 0x0B
- 3. 0x06 = 0x00
- 4. 0x07 = 0x00
- 5. 0x09 = 0x04
- 6. 0x11 = 0x05
- 7. 0x12 = 0x80
- 8. 0x08 = 0x21
- 9. 0x0A = 0x05
- 10.0x0B = 0x7F
- 11. 0x0C = 0x7E
- 12.0x0D = 0x01
- 13. 0x10 = 0x00
- 14.0x0E = 0x0915.0x0F = 0x04

#### **Example 2**. To configure for ARC Single Mode only:

- 1. 0x04 = 0xC9
- 2. 0x05 = 0x0B
- 3. 0x06 = 0x00
- 4. 0x07 = 0x00
- 5. 0x09 = 0x04
- 6. 0x11 = 0x04
- 7. 0x12 = 0x40
- 8. 0x08 = 0x00
- 9. 0x0A = 0x00
- 10.0x0B = 0x00
- 11. 0x0C = 0x0012. 0x0D = 0x00
- 13. 0x10 = 0x00
- 14.0x0E = 0x39
- 15. 0x0F = 0x04

### **Example 3**. To configure for HEC only:

- 1. 0x04 = 0xC9
- 2. 0x05 = 0x0B
- 3. 0x06 = 0x00
- 4. 0x07 = 0x00
- 5. 0x09 = 0x04
- 6. 0x11 = 0x057. 0x12 = 0x80
- 8. 0x08 = 0x21
- 9. 0x0A = 0x05
- 10. 0x0B = 0x7F
- 11. 0x0C = 0x7E
- 12. 0x0D = 0x01
- 13. 0x10 = 0x00
- 14.0x0E = 0x00
- 15. 0x0F = 0x00

# Appendix D – SiI9136 Tx and SiI9334 Tx Features

The SiI9136 Tx and SiI9334 Tx offer special features not provided in other TPI transmitters.

- Extra support is provided for x.v.Color operation.
- 3D video mode capability provides support for many 3D modes listed in the HDMI 1.4 specification.
- General Purpose I/O (GPIO) pins can be configured to meet custom requirements.
- HEAC support is detailed in Appendix C.
- 16-bit color depth is programmable through the standard input and output format registers at 0x09-0A.

Additional information is provided below on the x.v.Color, GPIO, and 3D features.

# **Special x.v.Color Features**

The SiI9136 Tx and SiI9334 Tx provide color space conversion and dedicated GBD packet support to improve x.v.Color operation. The color space conversion is described below; the GBD packet support is noted in the 3D Support section that follows.

### **Color Space Conversion**

The SiI9136 Tx and SiI9334 Tx offer a color space converter that can map incoming RGB to the x.v.Color space.

For x.v.Color operation without any color space conversion, the programming is the same as the YCbCr 4:4:4 mode of operation: TPI 0x09[3:0] need to be set to 0x09, and TPI 0x0A[3:0] to 0x05. Conversion of data width and dithering is configurable as shown in Table 9 (video input/output format registers 0x09/0x0A bits [7:4]).

For x.v.Color operation with color space conversion, some additional programming is required. First, set TPI 0x09[3:0]=0x00 and TPI 0x0A[3:0]=0x01 to select RGB to YCbCr 4:4:4 conversion. Then, program the following sequence:

The bit mapping of the x.v.Color configuration register written to TPI 0xBE is shown in the table below.

#### Table D - 1. x.v.Color Control (R/W)

|                       | Bit 7 | Bit 6 | Bit 5 | Bit 4        | Bit 3          | Bit 2       | Bit 1          | Bit 0                   |
|-----------------------|-------|-------|-------|--------------|----------------|-------------|----------------|-------------------------|
| Internal              |       |       |       | x.v.Color Co | ntrol Register |             |                |                         |
| Register<br>available |       |       |       |              |                | Coefficient | x.v.Color full | RGB to                  |
| at 0xBE               |       |       |       |              |                | Override    | scale output   | x.v.Color               |
| when:                 |       |       |       | 7,           |                | 0 – Disable | 0 – Disable    | conversion              |
| 0xBC=00               |       |       | XX    |              |                | (default)   | (default)      | 0 – Disable             |
| 0xBD=50               |       | 60    |       |              |                | 1 – Enable  | 1 – Enable     | (default)<br>1 – Enable |

Bit 2 of this register allows overriding the internal coefficient table for RGB to x.v.Color conversion. The coefficient table is mapped for access one byte at a time as shown in the table below. Software uses it to load the conversion matrix: TPI 0xBD to select the Index for the low or high byte of each 16-bit coefficient word, and TPI 0xBE to write the corresponding byte. Note that every index from 0x51 to 0x62 needs to be programmed to get satisfactory results.

Table D - 2. x.v.Color Coefficient Override Table Access (R/W)

|                    | R to Y | G to Y | B to Y | R to Cb | G to Cb | B to Cb | R to Cr | B to Cr | C to Cr |
|--------------------|--------|--------|--------|---------|---------|---------|---------|---------|---------|
| Index, bits [15:8] | 0x52   | 0x54   | 0x56   | 0x58    | 0x5A    | 0x5C    | 0x5E    | 0x60    | 0x62    |
| Index, bits [7:0]  | 0x51   | 0x53   | 0x55   | 0x57    | 0x59    | 0x5B    | 0x5D    | 0x5F    | 0x61    |

# **3D Support**

HDMI 1.4 defines 3D operation over HDMI. The SiI9136 Tx and SiI9334 Tx support 3D mode timing, and make special provisions to accommodate the extra InfoFrames needed.

A 3D video format is defined by the Video Identification Code (VIC) defined in the CEA-861-D standard, table 2, in conjunction with one of the extended 3D\_Structure values defined in the HDMI 1.4 standard, table H-2. In addition to sending the VIC to the receiver using the standard AVI InfoFrame format, the transmitter needs to send the 3D\_Structure value to the receiver using the HDMI Vendor Specific InfoFrame, defined in HDMI 1.4, sections 8.2.3, H.1 and H.2.

#### **3D Formats Supported**

The following 3D formats and resolutions are tested and supported, and include Deep Color depths up to 12 bits.

- 720p 50Hz Frame Packing
- 720p 59.94/60Hz Frame Packing
- 1080i 50Hz Frame Packing
- 1080i 59.94/60Hz Frame Packing
- 1080p 23.98/24Hz Frame Packing
- 1080i 50Hz Side-by-Side (Half)
- 1080i 59.94/60Hz Side-by-Side (Half)
- 1080p 23.98/24Hz Side-by-Side (Full)
- 720p 50Hz Side-by-Side (Full)
- 720p 59.94/60Hz Side-by-Side (Full)
- 720p 50Hz L+depth
- 720p 59.94/60Hz L+depth
- 1080p 23.98/24Hz L+depth

#### **HDMI Vendor Specific InfoFrame**

The HDMI Vendor Specific InfoFrame carries the 3D information to the receiver. It is defined in the HDMI 1.4 standard, sections 8.2.3, H.1, H.2. When the Tx transmits a 3D video signal, it must send an accurate HDMI Vendor Specific InfoFrame at least once per two video fields.

The HDMI Vendor Specific InfoFrame header is shown in the HDMI 1.4 specification. The fields that need to be set for transmission by the Tx are:

- 3D Structure, per HDMI 1.4 standard, table H-2.
- 3D\_Ext\_Data, for "Side-by-Side (Half)" only. It should be set to the required sampling method per the HDMI 1.4 standard, table H-3 (for example, set to 0 for "odd/left, odd/right horizontal sub-sampling method").

It is recommended that the MPEG InfoFrame buffer category be used for this InfoFrame type. The SiI9136 Tx and SiI9334 Tx offer a dedicated buffer, category 7, for GBD data. When category 7 (0xBF[2:0]= 111) is used for the GBD packet, it leaves category 3 (0xBF[2:0]= 011) available for the HDMI Vendor Specific InfoFrame entry.

The entry below is taken from Table 16 and emphasizes the recommended usage for SiI9136/9334 transmitters.

Table D - 3. SiI9136/9334 Tx InfoFrame Options (R/W)

| Offset | Bit 7      | Bit 6  | Bit 5 | Bit 4 | Bit 3 | Bit 2               | Bit 1                                  | Bit 0 |  |  |
|--------|------------|--------|-------|-------|-------|---------------------|----------------------------------------|-------|--|--|
| 0xBF   | I-F_SELECT |        |       |       |       |                     |                                        |       |  |  |
| [00]   | Enable     | Repeat |       | Rsvd  |       |                     | Info Frame to load (SiI9136/9334 only) |       |  |  |
|        |            |        |       |       |       |                     |                                        |       |  |  |
|        |            |        |       |       |       | 110 – HDMI VSIF     |                                        |       |  |  |
|        |            |        |       |       |       | 111 – Dedicated GBD |                                        |       |  |  |

#### Silicon Image, Inc.

### Sink EDID Vendor Specific Data Block

HDMI 1.4 extends the Vendor Specific Data Block (VSDB) of the sink EDID to include information about the sink 3D support capabilities. The Tx firmware needs to parse that information in order to limit the sending of 3D video to sinks that support that 3D format.

Detailed specifications of the EDID VSDB are listed in the HDMI 1.4 standard, section H.3.

#### Pixel Clock

Except for the Side-by-Side (Half) 3D modes, all 3D modes supported require doubling of the pixel clock frequency, compared to the pixel clock frequency used with 2D video modes that have the same VIC.

Doubling the pixel clock is described in the Deep Color Operation paragraph of the Input Bus Format and Pixel Repetition section.

#### Limitations

Color space conversion is generally supported. However, support in Side-by-side format is limited – edge pixels (on the border between left and right images) will not be converted correctly and must be discarded. No color space conversion support is provided in 3D L+depth modes.

# **General Purpose I/O**

The GPIO Pins can either act as inputs or outputs. The direction is configured individually, per pin, as noted in the table below.

Table D - 4. GPIO Configuration

| Internal Registers available at 0xBE when: | Bit 7                                                                  | Bit 6 | Bit 5 | Bit 4          | Bit 3                                                          | Bit 2                                                          | Bit 1                                              | Bit 0                                              |  |  |  |
|--------------------------------------------|------------------------------------------------------------------------|-------|-------|----------------|----------------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------|----------------------------------------------------|--|--|--|
|                                            | GPIO Rising Edge Trigger Register (R/W)                                |       |       |                |                                                                |                                                                |                                                    |                                                    |  |  |  |
| 0xBC= <b>03</b><br>0xBD= <b>E0</b><br>[00] |                                                                        |       |       |                | Assert INT#<br>on rising<br>GPIO3<br>0 – Disable<br>1 – Enable | Assert INT#<br>on rising<br>GPIO2<br>0 – Disable<br>1 – Enable | Assert INT# on rising GPIO1 0 – Disable 1 – Enable | Assert INT# on rising GPIO0 0 – Disable 1 – Enable |  |  |  |
|                                            | GPIO Falling Edge Trigger Register (R/W)                               |       |       |                |                                                                |                                                                |                                                    |                                                    |  |  |  |
| 0xBC=03<br>0xBD= <b>E1</b><br>[00]         |                                                                        |       |       | X              | Assert INT# on falling GPIO3 0 – Disable                       | Assert INT# on falling GPIO2 0 – Disable                       | Assert INT# on falling GPIO1 0 – Disable           | Assert INT# on falling GPIO0 0 – Disable           |  |  |  |
|                                            |                                                                        |       |       |                | 1 – Enable                                                     | 0 – Disable<br>1 – Enable                                      | 1 – Enable                                         | 0 – Disable<br>1 – Enable                          |  |  |  |
| 0xBC= <b>00</b>                            | GPIO Interrupt Status Register (R/W) Write '1' to clear pending status |       |       |                |                                                                |                                                                |                                                    |                                                    |  |  |  |
| 0xBD= <b>75</b><br>[00]                    |                                                                        |       |       | ). (1          | GPIO3 Event Pending 0=No 1=Yes                                 | GPIO2 Event Pending 0=No 1=Yes                                 | GPIO1 Event Pending 0=No 1=Yes                     | GPIO0 Event Pending 0=No 1=Yes                     |  |  |  |
|                                            | •                                                                      |       |       | GPIO Data Inpu | ıt Register (RO                                                |                                                                |                                                    |                                                    |  |  |  |
| 0xBC=03<br>0xBD= <b>E3</b><br>[00]         | Ġ                                                                      |       |       |                | GPIO3<br>0=Low<br>1=High                                       | GPIO2<br>0=Low<br>1=High                                       | GPIO1<br>0=Low<br>1=High                           | GPIO0<br>0=Low<br>1=High                           |  |  |  |
|                                            |                                                                        |       | Gl    | PIO Data Outp  | ut Register (R/                                                | W)                                                             |                                                    |                                                    |  |  |  |
| 0xBC= <b>03</b><br>0xBD= <b>E2</b><br>[00] |                                                                        |       |       |                | GPIO3<br>0=Low<br>1=High                                       | GPIO2<br>0=Low<br>1=High                                       | GPIO1<br>0=Low<br>1=High                           | GPIO0<br>0=Low<br>1=High                           |  |  |  |

**GPIO Interrupt Status.** Shows current status of GPIO trigger events that have been enabled in the Trigger registers. Write 1 to interrupt bits to clear the 'pending' status.

**Example.** The following describes how to configure GPIO0 and GPIO2 as input and GPIO1 and GPIO3 as output pins:

- a) Write 0xBC=0x03
- b) Write 0xBD=0xE0
- c) Write 0xBE=0x05 // set  $OE_N$  for GPIO0 and GPIO2 pads

After configuring the pin polarity, output data is written using the sequence:

- a) Write 0xBC=0x03
- b) Write 0xBD=0xE2
- c) Write 0xBE=0x0A // set output Pins GPIO1 and GPIO3 to 1

#### Reading input of GPIO is done by:

- a) Write 0xBC=0x03
- b) Write 0xBD=0xE3
- c) Read 0xBE

#### **Disclaimers**

These materials are provided on an "AS IS" basis. Silicon Image, Inc. and its affiliates disclaim all representations and warranties (express, implied, statutory or otherwise), including but not limited to: (i) all implied warranties of merchantability, fitness for a particular purpose, and/or non-infringement of third party rights; (ii) all warranties arising out of course-of-dealing, usage, and/or trade; and (iii) all warranties that the information or results provided in, or that may be obtained from use of, the materials are accurate, reliable, complete, up-to-date, or produce specific outcomes. Silicon Image, Inc. and its affiliates assume no liability or responsibility for any errors or omissions in these materials, makes no commitment or warranty to correct any such errors or omissions or update or keep current the information contained in these materials, and expressly disclaims all direct, indirect, special, incidental, consequential, reliance and punitive damages, including WITHOUT LIMITATION any loss of profits arising out of your access to, use or interpretation of, or actions taken or not taken based on the content of these materials.

Silicon Image, Inc. and its affiliates reserve the right, without notice, to periodically modify the information in these materials, and to add to, delete, and/or change any of this information.

Notwithstanding the foregoing, these materials shall not, in the absence of authorization under U.S. and local law and regulations, as required, be used by or exported or re-exported to (i) any U.S. sanctioned or embargoed country, or to nationals or residents of such countries; or (ii) any person, entity, organization or other party identified on the U.S. Department of Commerce's Denied Persons or Entity List, the U.S. Department of Treasury's Specially Designated Nationals or Blocked Persons List, or the Department of State's Debarred Parties List, as published and revised from time to time; (iii) any party engaged in nuclear, chemical/biological weapons or missile proliferation activities; or (iv) any party for use in the design, development, or production of rocket systems or unmanned air vehicles.

#### **Products and Services**

The products and services described in these materials, and any other information, services, designs, know-how and/or products provided by Silicon Image, Inc. and/or its affiliates are provided on as "AS IS" basis, except to the extent that Silicon Image, Inc. and/or its affiliates provides an applicable written limited warranty in its standard form license agreements, standard Terms and Conditions of Sale and Service or its other applicable standard form agreements, in which case such limited warranty shall apply and shall govern in lieu of all other warranties (express, statutory, or implied). EXCEPT FOR SUCH LIMITED WARRANTY, SILICON IMAGE, INC. AND ITS AFFILIATES DISCLAIM ALL REPRESENTATIONS AND WARRANTIES (EXPRESS, IMPLIED, STATUTORY OR OTHERWISE), REGARDING THE INFORMATION, SERVICES, DESIGNS, KNOW-HOW AND PRODUCTS PROVIDED BY SILICON IMAGE, INC. AND/OR ITS AFFILIATES, INCLUDING BUT NOT LIMITED TO, ALL IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND/OR NON-INFRINGEMENT OF THIRD PARTY RIGHTS. YOU ACKNOWLEDGE AND AGREE THAT SUCH INFORMATION, SERVICES, DESIGNS, KNOW-HOW AND PRODUCTS HAVE NOT BEEN DESIGNED, TESTED, OR MANUFACTURED FOR USE OR RESALE IN SYSTEMS WHERE THE FAILURE, MALFUNCTION, OR ANY INACCURACY OF THESE ITEMS CARRIES A RISK OF DEATH OR SERIOUS BODILY INJURY, INCLUDING, BUT NOT LIMITED TO, USE IN NUCLEAR FACILITIES, AIRCRAFT NAVIGATION OR COMMUNICATION, EMERGENCY SYSTEMS, OR OTHER SYSTEMS WITH A SIMILAR DEGREE OF POTENTIAL HAZARD. NO PERSON IS AUTHORIZED TO MAKE ANY OTHER WARRANTY OR REPRESENTATION CONCERNING THE PERFORMANCE OF THE INFORMATION, PRODUCTS, KNOW-HOW. DESIGNS OR SERVICES OTHER THAN AS PROVIDED IN THESE TERMS AND CONDITIONS.



1060 E. Arques Avenue

Sunnyvale, CA 94085

T 408.616.4000 F 408.830.9530

www.siliconimage.com



1060 E. Arques Avenue

Sunnyvale, CA 94085

T 408.616.4000 F 408.830.9530

www.siliconimage.com